一、题目
函数原型
int firstUniqChar(char* s)
二、算法设置一个大小为26的字符数组,位置0 - 25 分别对应字符 a - z 。遍历两次字符串,第一次记录下每个字符出现的次数,第二次检查哪个字符最先遍历到且出现次数为1,返回该字符即可。
三、代码
cppint firstUniqChar(char* s) { int nums[26]={0}; memset(nums,0,sizeof(nums)); int sz=strlen(s); for(int i=0;i<sz;i++) { nums[s[i]-'a']++; } for(int i=0;i<sz;i++) { if(nums[s[i]-'a']==1) return i; } return -1; }
leetcode:387. 字符串中的第一个唯一字符
南林yan2023-11-05 8:28
相关推荐
MobotStone3 小时前
Google发布Nano Banana 2:更快更便宜,图片生成能力全面升级颜酱7 小时前
队列练习系列:从基础到进阶的完整实现用户5757303346247 小时前
两数之和:从 JSON 对象到 Map,大厂面试官到底在考察什么?程序猿追7 小时前
“马”上行动:手把手教你基于灵珠平台打造春节“全能数字管家”ZPC82101 天前
docker 镜像备份ZPC82101 天前
docker 使用GUI ROS2琢磨先生David1 天前
Day1:基础入门·两数之和(LeetCode 1)颜酱1 天前
栈的经典应用:从基础到进阶,解决LeetCode高频栈类问题多恩Stone1 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系生信大杂烩1 天前
癌症中的“细胞邻域“:解码肿瘤微环境的空间密码 ——Nature Cancer 综述解读