#include <iostream>
#include <cstring>
using namespace std;
int main(){
int check=0;
int len;
char s[10000];
cin >> s;
len = strlen(s);
int letter[26] = {0};//26个字母
for(int i = 0 ; i < len ; i ++)
{
letter[s[i]-'a']++;
}
for(int i = 0 ; i < len ; i ++)
{
if(letter[s[i]-'a'] == 1)
{
cout << s[i];
return 0;
}
}
cout << -1 << endl;
return 0;
}
###### 这个是在一串字母中找首个不重复的字母
###### a的ASCII是97 A是65 如果s【i】是A那么 letter[s[i]-'a']中的s[i]-'a'就是负的了,为什么还能运行?最后的输出-1如果输出了不重复的字母是不是先将它的AScii减一再输出?
数组长度是负的为什么还能运行?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- 校歪歪 2021-11-27 21:50关注
C++不强制检查数组的下标越界,它会根据越界的下标在内存中继续查找,不会报错。所以使用数组要严格控制好下标的范围。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 单片机学习顺序问题!!
- ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
- ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
- ¥15 相敏解调 matlab
- ¥15 求lingo代码和思路
- ¥15 公交车和无人机协同运输
- ¥15 stm32代码移植没反应
- ¥15 matlab基于pde算法图像修复,为什么只能对示例图像有效
- ¥100 连续两帧图像高速减法
- ¥15 如何绘制动力学系统的相图