leetcode 387. First Unique Character in a String

题干

给定一个字符串,找到第一个非重复字符并输出

思路

两次循环,
第一次循环,使用map,key是字符,value记录出现的次数
第二次循环,找到value为1的key在字符串中的位置

代码

class Solution {
    public int firstUniqChar(String s) {
        Map<Character,Integer>map=new HashMap<Character,Integer>();
        char [] cstr=s.toCharArray();
        for(char c:cstr){
            //c有对应的value就取,如果没有,默认为0,然后将这个值+1,计数
            map.put(c,map.getOrDefault(c,0)+1);
        }	
        int i=0;
        for(char c:cstr){
            if(map.get(c)==1)
                return i;
            i++;
        }
        return -1;
    }
}

python

class Solution:
    def firstUniqChar(self, s):
        #这个count包含了字符和其对应的出现次数
        count=collections.Counter(s)
        
        index=0
        for c in s:
            if count[c]==1:
                return index
            else:
                index+=1
        return -1
            
全部评论

相关推荐

06-12 17:46
门头沟学院 Java
运营你豪哥:来说重点: ​1.项目前置,时间倒序。​​ 2.​项目描述强化结果与量化效果(STAR原则里的R)。​​ ​3.个人技能精炼,明确掌握程度,突出核心。​​ ​4.增加强有力开头的个人总结部分。​​ 5.​优化教育背景(成绩排名)、合并奖项与活动。​​
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
点赞 评论 收藏
分享
就在我现在公司的隔壁每天经过都唏嘘不已(就是羡慕)什么时候可以到这里上班啊
柯基在debug:从大学毕业投简历到现在了,应届的时候我都面到终面了,现在工作四年了连简历初筛都过不了了
投递莉莉丝游戏等公司8个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务