题解 | #找出字符串中第一个只出现一次的字符#

找出字符串中第一个只出现一次的字符

https://www.nowcoder.com/practice/e896d0f82f1246a3aa7b232ce38029d4

#include<iostream>
using namespace std;

//暴力法
char GetFirstOneChar(const string &str)
{
    int j=0;
    for(int i=0;i<str.size();++i)
    {
        for(j=0;j<str.size();++j)
        {
            if(j==i)
                continue;
            if(str[i]==str[j])
                break;
        }
        if(j>=str.size())
            return str[i];
    }
    return -1;
}
//哈希法
char GetFirstOneChar_Hash(const string &str)
{
    int hash[256]={0};
    for(int i=0;i<str.size();++i)
    {
        hash[str[i]]++;   //统计字符出现的次数
    }
    for(int i=0;i<str.size();++i)
    {
        if(hash[str[i]]==1)
        return str[i];
    }
    return -1;
}
//string类函数查找法
char GetFirstOneChar_String(const string &str)
{
    for(int i=0;i<str.size();++i)
    {
        int index1=str.find(str[i]);
        int index2=str.rfind(str[i]);
        if(index1==index2)
        return str[i];
    }
    return -1;
}

int main()
{
    string str;
    char res;
    while(getline(cin,str))
    {
        //res=GetFirstOneChar(str);
        //res=GetFirstOneChar_Hash(str);
        res=GetFirstOneChar_String(str);
    if(res==-1)
        cout<<-1<<endl;
    else
        cout<<res<<endl;
    }
    return 0;
}

全部评论

相关推荐

最近和朋友聊天,她说了句让我震惊的话:"我发现我连周末点外卖都开始'最优解'了,一定要赶在高峰期前下单,不然就觉得自己亏了。"这不就是典型的"班味入侵"吗?工作思维已经渗透到生活的方方面面。
小型域名服务器:啊?我一直都这样啊?我还以为是我爱贪小便宜呢?每次去实验室都得接一杯免费的开水回去,出门都得规划一下最短路径,在宿舍就吃南边的食堂,在实验室就吃北边的食堂,快递只有顺路的时候才取。
点赞 评论 收藏
分享
头像
11-09 12:17
清华大学 C++
out11Man:小丑罢了,不用理会
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务