找第一个只出现一次的字符(信息学奥塞一本通-1130)
【题目描述】
给定一个只包含小写字母的字符串,请你找到第一个仅出现一次的字符。如果没有,输出no。
【输入】
一个字符串,长度小于100000。
【输出】
输出第一个仅出现一次的字符,若没有则输出no。
【输入样例】
abcabd
【输出样例】
c
【题解代码】
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
int cnt[N];
int main()
{
string s; getline(cin, s);
for (int i = 0; i < s.size(); i++)
{
cnt[s[i]]++;
}
for (int i = 0; i < s.size(); i++)
{
if (cnt[s[i]] == 1)
{
cout << s[i];
return 0;
}
}
cout << "no";
return 0;
}