当前位置: 首页 > news >正文

【OJ题解】在字符串中查找第一个不重复字符的索引

💵个人主页: 起名字真南
💵个人专栏:【数据结构初阶】 【C语言】 【C++】 【OJ题解】

请添加图片描述

目录

  • 1. 引言
  • 2. 题目分析
    • 示例:
  • 3. 解题思路
    • 思路一:双重循环
    • 思路二:哈希表
  • 4. C++代码实现
  • 5. 代码详解
  • 6. 时间和空间复杂度分析
  • 7. 优化方法
    • 使用哈希表优化的思路:
  • 8. 时间和空间复杂度分析(哈希表实现)
  • 9. 总结

1. 引言

在字符串处理相关问题中,查找第一个不重复字符的索引是一个经典题目。特别是在高并发环境中,我们可能需要高效判断某个字符串的字符是否有重复。本文将详细解析如何在给定字符串中找到第一个不重复字符的索引。

2. 题目分析

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

在字符串中查找第一个不重复字符的索引题目链接

示例:

  • 示例 1:
    • 输入:s = "leetcode"
    • 输出:0(因为第一个不重复字符是 l,索引为 0)
  • 示例 2:
    • 输入:s = "loveleetcode"
    • 输出:2(第一个不重复字符是 v,索引为 2)
  • 示例 3:
    • 输入:s = "aabb"
    • 输出:-1(所有字符都重复)

3. 解题思路

这道题可以通过双重循环哈希表两种思路来实现。双重循环简单直接,但在处理大型字符串时效率较低。本文将以双重循环方法为主,之后讨论优化方法。

思路一:双重循环

我们逐个检查字符串中的每个字符,并在整个字符串中寻找其他相同字符。若发现相同字符,则跳过;否则,返回该字符的索引。

思路二:哈希表

可以用哈希表记录每个字符出现的次数。之后再遍历字符串,查找第一个只出现一次的字符。

4. C++代码实现

以下为C++代码,使用双重循环来实现第一个不重复字符的查找:

class Solution {
public:int firstUniqChar(string s) {int len = s.size();// 遍历字符串中的每个字符for (int i = 0; i < len; i++) {bool isUnique = true; // 假设当前字符是唯一的for (int j = 0; j < len; j++) {// 检查是否有其他相同字符if (s[i] == s[j] && i != j) {isUnique = false;break;}}// 如果是唯一字符,返回其索引if (isUnique) {return i;}}return -1; // 没有找到不重复字符}
};

5. 代码详解

  • 外层循环:遍历字符串中的每一个字符 s[i],并假设该字符是唯一的。
  • 内层循环:检查 s[i] 是否在其他位置出现:
    • 如果找到与 s[i] 相同的字符,则将 isUnique 标记为 false,并跳出内层循环。
  • 返回索引:如果 isUnique 仍然为true,表示当前字符是唯一的,返回它的索引i
  • 返回-1:如果遍历结束没有找到不重复字符,返回 -1

6. 时间和空间复杂度分析

  • 时间复杂度:O(n^2),其中 n 是字符串的长度。外层循环遍历字符串中的每个字符,内层循环遍历整个字符串来寻找重复字符,因此时间复杂度为 O(n^2)。
  • 空间复杂度:O(1),仅使用了常数级额外空间。

7. 优化方法

尽管双重循环方法简单易懂,但在长字符串中效率较低。可以使用哈希表优化到线性时间复杂度。

使用哈希表优化的思路:

  1. 首次遍历字符串,将每个字符的出现次数记录到哈希表中。
  2. 再次遍历字符串,找到第一个只出现一次的字符并返回其索引。

优化后的代码如下:

#include <unordered_map>class Solution {
public:int firstUniqChar(string s) {unordered_map<char, int> countMap;// 统计每个字符出现的次数for (char c : s) {countMap[c]++;}// 再次遍历字符串,找到第一个只出现一次的字符for (int i = 0; i < s.size(); i++) {if (countMap[s[i]] == 1) {return i;}}return -1;}
};

8. 时间和空间复杂度分析(哈希表实现)

  • 时间复杂度:O(n),因为哈希表方法只需要两次遍历字符串。
  • 空间复杂度:O(1),因为哈希表中的键值对不会超过字符数量。

9. 总结

本文介绍了如何查找字符串中第一个不重复字符的索引。虽然双重循环方法能有效解决问题,但在大型数据下不够高效。哈希表优化方法可以大幅提升效率,适用于各种字符串长度。希望通过此文章能帮助大家更好地理解字符串不重复字符查找的实现。

今后可以探索更多优化方法,如基于字符ASCII码的统计数组,以实现更快的查找操作。


http://www.mrgr.cn/news/66329.html

相关文章:

  • 【热门主题】000029 ECMAScript:现代编程的基石
  • 服装品牌零售业态融合中的创新发展:以开源 AI 智能名片 S2B2C 商城小程序为视角
  • 【用Java学习数据结构系列】泛型上界与通配符上界
  • DPDK 简易应用开发之路 6:流规则配置与多队列数据包处理
  • 摄影分享网站(源码+数据库+报告)
  • Linux:生态与软件安装
  • 华为HarmonyOS借助AR引擎帮助应用实现虚拟与现实交互的能力5-识别平面语义
  • 【LeetCode】【算法】146. LRU缓存
  • Python学习笔记-生成器的应用与原理
  • 好看的超清4K视频素材去哪儿找?下载素材资源网站推荐
  • AI大模型重塑软件开发:流程、优势、挑战与展望
  • 「C/C++」C/C++标准库 之 #include<cctype> 字符分类处理库
  • 牛客周赛 66 F 小苯的字符提前
  • 进程的调度(超详细解读)
  • Day 49 || 1143.最长公共子序列、1035.不相交的线、 53. 最大子序和 、392.判断子序列
  • Java入门(8)--反射机制
  • 零基础学习Spring AI Java AI SpringBoot AI调用大模型OpenAi Ollama集成大模型
  • HarmonyOS开发 - Ability往页面(Pages)中传递数据
  • 年薪平均几十万?!哪些行业的软件测试工程师需求量大,前景好?
  • ubuntu工具 -- ubuntu服务器临时没有网络,急需联网下载东西怎么办? 使用手机提供网络
  • @ApiOperation(“修改帐号状态“)详细解释一下以上代码
  • 视频监控接入平台功能:视频平台系统的硬件性能直观显示和系统软件运行情况和状态显示
  • 【初阶数据结构篇】链式结构二叉树(续)
  • vue组件在项目中的常用业务逻辑(3)
  • 11.5 dmy NOIP模拟赛DAY4 总结
  • operator[ ]和迭代器,auto,for流,reserve