一、前言
本系列文章为《剑指Offer》刷题笔记。
刷题平台:牛客网
书籍下载:共享资源
二、题目
在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置。
1、思路
建立一个哈希表,第一次扫描的时候,统计每个字符的出现次数。第二次扫描的时候,如果该字符出现的次数为1,则返回这个字符的位置。
2、代码
C++:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | class Solution { public: int FirstNotRepeatingChar(string str) { int length = str.size(); if(length == 0){ return -1; } map<char, int> item; for(int i = 0; i < length; i++){ item[str[i]]++; } for(int i = 0; i < length; i++){ if(item[str[i]] == 1){ return i; } } return -1; } }; |
Python:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | # -*- coding:utf-8 -*- class Solution: def FirstNotRepeatingChar(self, s): # write code here length = len(s) if length == 0: return -1 item = {} for i in range(length): if s[i] not in item.keys(): item[s[i]] = 1 else: item[s[i]] += 1 for i in range(length): if item[s[i]] == 1: return i return -1 |
微信公众号
分享技术,乐享生活:微信公众号搜索「JackCui-AI」关注一个在互联网摸爬滚打的潜行者。
2018年4月24日 下午3:57 沙发
您好 c++里面map的item初值为0吗?++后不是1吗?
—统计只出现一次的。。。。看错了
2018年4月24日 下午4:40 1层
@到底对不对 0.0
2019年4月8日 下午11:19 板凳
您好,map item;构建item后,新建 item[str[i]] 对应的int默认值为0吗?
还有博主是在哪查找的STL里各种函数的用法啊,有没有像菜鸟教程查python这种,比较方便的查STL的网站推荐?谢谢了
2019年4月9日 上午10:11 1层
@Ryan_Wang 是0,自加后变成1。菜鸟教程也有c++ stl的。