【leetcode_C++_string】387.字符串中的第一个唯一字符

文章目录

1.题目

给定一个字符串 s ,找到它的第一个不重复的字符,并返回它的索引 。如果不存在,则返回 -1 。

示例 1:

输入: s = "leetcode"

输出: 0

示例 2:

输入: s = "loveleetcode"

输出: 2

示例 3:

输入: s = "aabb"

输出: -1

提示:

  • 1 <= s.length <= 105
  • s 只包含小写字母

2.题解

cpp 复制代码
class Solution {
public:
    int firstUniqChar(string s) {
        int size = s.size();

        //建立一个数组,用于统计每个字符出现的次数
        int count[256] = {0};//虽然只有26个字符,
        //但是这26个字符的ascall的值可不是0-26 所以需要空间256个

        //统计每个字符出现的次数
        for(int i = 0; i < size; i++)
        {
            count[s[i]] += 1;
        }

        //找第一个只出现一次的字符
        for(int i = 0; i < size; i++)
        {
            if (count[s[i]] == 1)
            return i; 
        }
        return -1;
    }
};
相关推荐
hkj880813 小时前
CRC-512算法输出64字节
算法
@我漫长的孤独流浪13 小时前
计算机系统核心概念与性能优化全解析
算法·计算机外设
如竟没有火炬13 小时前
接雨水22
数据结构·python·算法·leetcode·散列表
ʚ希希ɞ ྀ13 小时前
二叉树的锯齿层序遍历
数据结构·算法
June`14 小时前
高并发内存池如何实现
c++·tcmalloc·内存池
ComputerInBook14 小时前
C++ 关键字 constexpr 和 consteval 之注意事项
开发语言·c++·constexpr·consteval
澈20714 小时前
二叉搜索树:高效增删查的秘诀
java·开发语言·算法
米啦啦.14 小时前
STL(标准模板库)
开发语言·c++·stl
无敌昊哥战神14 小时前
大模型(LLM)推理优化技术全景总结
python·算法·大模型
平行侠14 小时前
A10 恶劣环境传感器信号仿真与统计检验台
算法