首页 > 代码库 > 给定一个字符串,找到第一个只出现一次的字符的下标,找不到输出-1。
给定一个字符串,找到第一个只出现一次的字符的下标,找不到输出-1。
1. 给定一个字符串,找到第一个只出现一次的字符的下标,找不到输出-1。
sample:
输入:“abcdefcba”
输出:3
解法:先遍历字符串,用一个map记录每个字符出现的次数,再次遍历字符串,找到第一个只出现一次的字符,复杂度为O(n)。
#include <iostream>
#include <string>
#include <cstring>
#include <map>
using namespace std;
int getCharIndex(const char *str)
{
map<char, int> cmap;
int length = strlen(str);
for (int i = 0; i < length; ++i)
++ cmap[str[i]];
int ret = -1;
for (int i = 0; i < length; ++i)
if (cmap[str[i]] == 1)
{
ret = i;
break;
}
return ret;
}
int main()
{
string str;
cin >> str;
cout << getCharIndex(str.c_str()) << endl;
}
给定一个字符串,找到第一个只出现一次的字符的下标,找不到输出-1。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。