Leetcode每日刷题之字符串中的第一个唯一字符(C++)

在学习的过程中对代码的熟练运用至关重要,练习解决实际问题就可以很好的锻炼自己的编程能力,接下来让我们练习这道 387.字符串中的第一个唯一字符

思路解析

根据题意我们可以知道这个字符串只有小写字母,并且可能包含多个唯一字符,也可能没有唯一字符,所以我们要解决问题的核心要点就是

1. 找出所有唯一字符

2. 找出第一次出现的唯一字符

3. 如果没有唯一字符就返回 -1

接下来使用代码来进行详细解释

cpp 复制代码
class Solution {
public:
    int firstUniqChar(string s) 
    {
        int count[26] = {0};
        //范围 for 通过映射计数
        for(auto ch : s)
        {
            count[ch - 'a']++;
        }

        for(size_t i = 0;i < s.size();i++)
        {
            if(count[s[i] - 'a'] == 1)
                return i;
        }

        return -1;
    }
};

代码分析

1. 首先我们可以使用遍历的思想去依次枚举只出现了一次的唯一字符,然后再判断第一次出 现的字符

2. 这时我们可以使用计数排序的思想,就是开辟一个数字用来存储26个字母对应的出现次 数,即使用映射的思想来计数,使用 当前字母 - 'a' 当做下标,然后遍历用来计数的数组

3. 如果出现了唯一字符就返回其索引,也就是它的下标,反之返回 - 1

相关推荐
weixin_429630266 分钟前
3.41 一种高效的室内定位Wi-Fi视觉地图构建及自维护方法
算法
心中有国也有家7 分钟前
NPU性能调优完全攻略——从Profiler到算子调优的实战方法论
人工智能·经验分享·笔记·分布式·算法
Gauss松鼠会9 分钟前
GaussDB(DWS)数据融合:Oracle增量数据迁移到DWS
java·数据库·算法·oracle·性能优化·gaussdb
洛水水13 分钟前
【力扣100题】51.不同路径
算法·leetcode·职场和发展
ん贤15 分钟前
KServe 详细笔记
笔记·算法·贪心算法
吴可可12323 分钟前
C#处理CAD文件的主流库推荐
算法
MicroTech202528 分钟前
微算法科技(NASDAQ :MLGO)基于量子傅立叶变换的量子彩色图像加密算法
科技·算法·量子计算
人道领域31 分钟前
【LeetCode刷题日记】一篇搞懂->701.二叉搜索树的插入操作
java·数据结构·leetcode
Severus_black32 分钟前
【初阶数据结构与算法】八大排序之归并排序,递归与非递归,一次性讲清!
数据结构·算法·排序算法
sali-tec38 分钟前
C# 基于OpenCv的视觉工作流-章77-物体测量
图像处理·人工智能·opencv·算法·计算机视觉