【C++经典例题】寻找字符串中第一个不重复字符的索引

【C++经典例题】寻找字符串中第一个不重复字符的索引
           💓 博客主页:倔强的石头的ZEEKLOG主页 

           📝Gitee主页:
倔强的石头的gitee主页

            ⏩ 文章专栏:C++经典例题

                                  期待您的关注

 

目录

 

问题描述

解题方法

方法一:暴力解法

解题思路

代码实现

复杂度分析

 

方法二:计数排序解法

解题思路

代码实现

复杂度分析

 

总结


 

 

 

问题描述

给定一个只包含小写字母的字符串 s,我们的目标是找到它的第一个不重复的字符,并返回该字符在字符串中的索引。如果字符串中不存在这样的字符,则返回 -1。1 <= s.length <= 105s 只包含小写字母

例如:

  • 对于字符串 "leetcode",字符 'l' 是第一个不重复的字符,其索引为 0,所以应返回 0。
  • 对于字符串 "loveleetcode",字符 'v' 是第一个不重复的字符,其索引为 2,所以应返回 2。
  • 对于字符串 "aabb",不存在不重复的字符,所以应返回 -1。

 

解题方法

方法一:暴力解法

解题思路

暴力解法的核心思想是对字符串中的每个字符,都遍历整个字符串,检查是否存在与它相同的其他字符。如果在遍历过程中没有找到相同的字符,那么该字符就是第一个不重复的字符,返回其索引;如果遍历完所有字符都没有找到不重复的字符,则返回 -1

 

代码实现

class Solution { public: int firstUniqChar(string s) //暴力解法 { int size = s.size(); for (int i = 0; i < size; ++i) { int flag = 1; for (int j = 0; j < size; ++j) { if ((s[i] == s[j]) && (i != j))//如果有相同的字符,就结束这轮对比 { flag = 0; break; } } if (flag == 1)//循环走完,标志没有被改变,说明没有相同的字符 return i; } return -1; } };

复杂度分析

  • 时间复杂度:(O(n^2)),其中 (n) 是字符串的长度。因为对于每个字符,都需要遍历整个字符串来检查是否有重复。当字符串很大时,这种方式会暴露出极大的效率问题
  • 空间复杂度:(O(1)),只使用了常数级的额外空间。

方法二:计数排序解法

解题思路

由于字符串只包含小写字母,小写字母一共有 26 个,我们可以使用一个长度为 26 的数组来记录每个字母在字符串中出现的次数。首先遍历字符串,统计每个字母的出现次数;然后再次遍历字符串,找到第一个出现次数为 1 的字母,并返回其索引;如果遍历完都没有找到,则返回 -1。

 

对于计数排序的详细讲解,可以参考我的另一篇文章:
【数据结构与算法】详解计数排序:小范围整数排序的最佳选择-ZEEKLOG博客

 

代码实现

class Solution { public: int firstUniqChar(string s) //计数排序解法 { int count[26] = {0};//创建数组映射存储次数,初始化为 0 int size = s.size(); for (int i = 0; i < size; ++i)//第一次遍历,记录次数 { ++count[s[i] - 'a']; } for (int i = 0; i < size; ++i)//第二次遍历,找到第一个只出现一次的字母 { if (count[s[i] - 'a'] == 1) return i; } return -1;//走到这里说明不存在 } };

复杂度分析

  • 时间复杂度:(O(n)),其中 (n) 是字符串的长度。需要遍历字符串两次,每次遍历的时间复杂度都是 (O(n))。
  • 空间复杂度:(O(1)),因为只使用了一个长度为 26 的数组,无论字符串多长,额外空间都是常数级的。

 

总结

暴力解法虽然简单直接,但时间复杂度较高,对于较长的字符串效率较低;

而计数排序解法利用了字符串只包含小写字母的特点,通过额外的数组来记录字母出现的次数,将时间复杂度优化到了线性级别,在处理大规模数据时性能更优。

 

在实际应用中,满足数据量大且范围相对集中的情况,我们应该优先选择计数排序这种高效的解法

Read more

星标超 28 万,OpenClaw 两天两次大更!适配GPT 5.4,告别“抽卡式 Prompt”

星标超 28 万,OpenClaw 两天两次大更!适配GPT 5.4,告别“抽卡式 Prompt”

整理 | 梦依丹 出品 | ZEEKLOG(ID:ZEEKLOGnews) “We don’t do small releases.” 这是 OpenClaw 在发布 2026.3.7 版本时写下的一句话。 刚刚过去的周六与周日,这个 GitHub 星标已超 28 万 的 AI Agent 开源项目再次迎来两轮重量级更新。 两天两次更新:OpenClaw 做了一次“真正的大版本升级” 打开 OpenClaw 的 GitHub 更新日志,你会发现这次版本更新的规模确实不小。在 3 月 7 日发布更新后,第二天又迅速推出 2026.3.8-beta.1 和

By Ne0inhk
为省5-10美元差点毁库!Claude一条指令删光200万条数据、网站停摆24小时,创始人坦言:全是我的错

为省5-10美元差点毁库!Claude一条指令删光200万条数据、网站停摆24小时,创始人坦言:全是我的错

编译 | 屠敏 出品 | ZEEKLOG(ID:ZEEKLOGnews) AI 时代,一次看似普通的操作,竟能让整套生产环境与近 200 万条数据瞬间「归零」。 近日,数据科学社区 DataTalks.Club 创始人 Alexey Grigorev 就遭遇了这样的惊魂时刻,他在使用 AI 编程工具 Claude Code 管理网站服务器时,意外清空了平台积累 2.5 年的核心数据,甚至连数据库快照也未能幸免,导致网站停摆整整 24 小时。 这起事故不仅在开发者社区引发热议,更给所有依赖 AI 工具与自动化运维的从业者敲响了警钟。事后,Alexey Grigorev 公开复盘了整个过程,并揭露了此次事故的核心问题。让我们一起看看。 一次看似很普通的网站迁移 这场“删库”事件的前因,其实并不复杂。

By Ne0inhk
苹果最贵手机要来了!折叠屏iPhone将于9月亮相;部分高校严禁校内使用OpenClaw;黄仁勋预言:传统软件和APP或将消失 | 极客头条

苹果最贵手机要来了!折叠屏iPhone将于9月亮相;部分高校严禁校内使用OpenClaw;黄仁勋预言:传统软件和APP或将消失 | 极客头条

「极客头条」—— 技术人员的新闻圈! ZEEKLOG 的读者朋友们好,「极客头条」来啦,快来看今天都有哪些值得我们技术人关注的重要新闻吧。(投稿或寻求报道:[email protected]) 整理 | 郑丽媛 出品 | ZEEKLOG(ID:ZEEKLOGnews) 一分钟速览新闻点! * 多所高校要求警惕 OpenClaw 安全风险,部分严禁校内使用 * 荣耀 CEO 李健:荣耀机器人全栈自研,将聚焦消费市场 * 马化腾凌晨 2 点发声:还有一批龙虾系产品陆续赶来 * 前快手语言大模型中心负责人张富峥,已加入智源人工智能研究院,负责 LLM 方向 * 最新全球 AI 应用百强榜发布,豆包/DeepSeek/千问上榜 * 苹果折叠 iPhone 将于九月亮相,融合 iPhone 与 iPad 体验

By Ne0inhk
不止“996”!曝硅谷AI创业圈「极限工作制」:每天16小时、凌晨3点下班、周末也在写代码

不止“996”!曝硅谷AI创业圈「极限工作制」:每天16小时、凌晨3点下班、周末也在写代码

编译 | 郑丽媛 出品 | ZEEKLOG(ID:ZEEKLOGnews) “如果你周日去旧金山的咖啡馆,会发现几乎每个人都在工作。” 这是 AI 创业公司 Mythril 联合创始人 Sanju Lokuhitige 最近最直观的感受。去年 11 月,他特地搬到旧金山,只为了更接近 AI 创业浪潮的中心。但很快,他也被卷入了这股浪潮带来的另一面——一种越来越极端的工作文化。 Lokuhitige 坦言,他现在几乎每天工作 12 小时,每周 7 天。除了每周少数几场刻意安排的社交活动(主要是为了和创业者们建立联系),其余时间几乎都在写代码、做产品。 “有时候我整整一天都在编程,”他说,“我基本没有什么工作与生活的平衡。”而这样的生活,在如今的 AI 创业圈里并不算罕见。 旧金山 AI 创业圈的真实日常 一位在旧金山一家 AI

By Ne0inhk