0

0

使用 indexOf 方法查找字符串中第一个唯一字符的教程

花韻仙語

花韻仙語

发布时间:2025-10-05 15:12:31

|

658人浏览过

|

来源于php中文网

原创

使用 indexof 方法查找字符串中第一个唯一字符的教程

本文详细阐述了如何利用 Java String 类的 indexOf 方法来高效地识别并返回字符串中第一个不重复字符的索引。通过深入解析 indexOf 方法的不同重载形式及其组合使用,我们将理解其判断字符唯一性的核心逻辑,并提供清晰的代码示例和逐步解析,帮助读者掌握这一技巧。

1. 理解 String 类的关键方法

在深入探讨查找唯一字符的逻辑之前,我们首先需要理解 Java String 类中两个核心方法的使用:charAt() 和 indexOf()。

1.1 charAt(int index) 方法

charAt(int index) 方法用于返回字符串中指定索引位置的字符。

  • 语法: public char charAt(int index)
  • 参数: index - 字符在字符串中的位置(从 0 开始)。
  • 返回值: 指定索引处的字符。
  • 示例: String s = "hello"; s.charAt(0) 将返回 'h'。

1.2 indexOf() 方法的重载形式

indexOf() 方法用于查找字符或子字符串在字符串中首次出现的位置。它有多种重载形式,其中两种对我们查找唯一字符至关重要:

  • indexOf(char ch):

    • 语法: public int indexOf(char ch)
    • 参数: ch - 要查找的字符。
    • 返回值: 字符首次出现的索引。如果未找到,则返回 -1。
    • 示例: String s = "banana"; s.indexOf('a') 将返回 1。
  • indexOf(char ch, int fromIndex):

    • 语法: public int indexOf(char ch, int fromIndex)
    • 参数:
      • ch - 要查找的字符。
      • fromIndex - 开始搜索的索引位置。
    • 返回值: 字符从 fromIndex 位置开始首次出现的索引。如果从 fromIndex 开始未找到,则返回 -1。
    • 示例: String s = "banana"; s.indexOf('a', 2) 将返回 3 (因为从索引 2 开始,'a' 首次出现在索引 3)。

2. 核心逻辑解析:如何判断字符唯一性

现在,我们来解析如何利用上述方法组合判断一个字符是否在字符串中是唯一的。核心判断条件是: s.indexOf(s.charAt(i), s.indexOf(s.charAt(i)) + 1) == -1

为了更好地理解这个表达式,我们将其分解:

  1. s.charAt(i): 在循环的当前迭代中,这会获取字符串 s 在索引 i 处的字符。我们称之为 currentChar。
  2. s.indexOf(currentChar): 这会查找 currentChar 在整个字符串 s 中首次出现的位置。例如,如果 s = "leetcode" 且 currentChar = 'l',s.indexOf('l') 将返回 0。
  3. s.indexOf(currentChar) + 1: 这将得到 currentChar 首次出现位置的下一个索引。这个值将作为我们第二次搜索的起始点。
  4. s.indexOf(currentChar, s.indexOf(currentChar) + 1): 这是最关键的一步。它会从 currentChar 首次出现位置的下一个索引开始,再次查找 currentChar。
    • 如果 currentChar 是唯一的(即它只出现一次),那么从其首次出现位置的下一个索引开始,将无法再找到 currentChar。在这种情况下,indexOf() 方法会返回 -1。
    • 如果 currentChar 不是唯一的(即它出现了多次),那么从其首次出现位置的下一个索引开始,indexOf() 方法将能够找到 currentChar 的另一次出现,并返回其索引(一个非 -1 的值)。
  5. == -1: 因此,当整个表达式 s.indexOf(s.charAt(i), s.indexOf(s.charAt(i)) + 1) == -1 为真时,就意味着 s.charAt(i) 在字符串中只出现了一次,它是一个唯一的字符。

3. 实现代码示例

下面是根据上述逻辑实现的 Java 代码,用于查找字符串中第一个唯一的字符的索引:

public class UniqueCharacterFinder {

    /**
     * 查找字符串中第一个不重复字符的索引。
     * 如果所有字符都重复,则返回 -1。
     *
     * @param s 输入字符串
     * @return 第一个不重复字符的索引,如果不存在则返回 -1
     */
    public static int findFirstUniqueCharIndex(String s) {
        // 遍历字符串中的每一个字符
        for (int i = 0; i < s.length(); i++) {
            char currentChar = s.charAt(i); // 获取当前字符

            // 查找当前字符在字符串中首次出现的位置
            int firstOccurrenceIndex = s.indexOf(currentChar);

            // 从首次出现位置的下一个索引开始,再次查找当前字符
            // 如果从这个位置开始找不到该字符(即返回 -1),则说明它是唯一的
            if (s.indexOf(currentChar, firstOccurrenceIndex + 1) == -1) {
                return i; // 返回当前唯一字符的索引
            }
        }
        return -1; // 如果循环结束都没有找到唯一字符,则返回 -1
    }

    public static void main(String[] args) {
        String testString1 = "leetcode";
        System.out.println("字符串 \"" + testString1 + "\" 中第一个唯一字符的索引是: " + findFirstUniqueCharIndex(testString1)); // 预期输出: 0 (l)

        String testString2 = "loveleetcode";
        System.out.println("字符串 \"" + testString2 + "\" 中第一个唯一字符的索引是: " + findFirstUniqueCharIndex(testString2)); // 预期输出: 2 (v)

        String testString3 = "aabb";
        System.out.println("字符串 \"" + testString3 + "\" 中第一个唯一字符的索引是: " + findFirstUniqueCharIndex(testString3)); // 预期输出: -1
    }
}

4. 工作原理演示 (以 "leetcode" 为例)

让我们逐步跟踪 findFirstUniqueCharIndex("leetcode") 的执行过程:

AI小聚
AI小聚

一站式多功能AIGC创作平台,支持AI绘画、AI视频、AI聊天、AI音乐

下载
  1. i = 0, currentChar = 'l':
    • s.indexOf('l') 返回 0。
    • s.indexOf('l', 0 + 1) 即 s.indexOf('l', 1)。从索引 1 开始,字符串 "eetcode" 中没有 'l'。所以 s.indexOf('l', 1) 返回 -1。
    • 条件 (-1 == -1) 为真,函数返回 i,即 0。

因此,对于 "leetcode",函数会立即返回 0,因为 'l' 是第一个唯一的字符。

让我们再看一个例子:"loveleetcode"

  1. i = 0, currentChar = 'l':

    • s.indexOf('l') 返回 0。
    • s.indexOf('l', 0 + 1) 即 s.indexOf('l', 1)。从索引 1 开始,字符串 "oveleetcode" 中存在 'l'(在索引 8)。所以 s.indexOf('l', 1) 返回 8。
    • 条件 (8 == -1) 为假。继续循环。
  2. i = 1, currentChar = 'o':

    • s.indexOf('o') 返回 1。
    • s.indexOf('o', 1 + 1) 即 s.indexOf('o', 2)。从索引 2 开始,字符串 "veleetcode" 中存在 'o'(在索引 9)。所以 s.indexOf('o', 2) 返回 9。
    • 条件 (9 == -1) 为假。继续循环。
  3. i = 2, currentChar = 'v':

    • s.indexOf('v') 返回 2。
    • s.indexOf('v', 2 + 1) 即 s.indexOf('v', 3)。从索引 3 开始,字符串 "eleetcode" 中没有 'v'。所以 s.indexOf('v', 3) 返回 -1。
    • 条件 (-1 == -1) 为真,函数返回 i,即 2。

因此,对于 "loveleetcode",函数返回 2,因为 'v' 是第一个唯一的字符。

5. 注意事项与性能考量

  • 时间复杂度: 尽管 indexOf 方法在 Java 内部经过高度优化,但在最坏情况下,每次 indexOf 调用都可能需要遍历字符串的一部分。在一个循环中嵌套 indexOf 调用,使得这种方法的整体时间复杂度接近 O(N^2),其中 N 是字符串的长度。对于非常长的字符串,这可能导致性能问题。
  • 空间复杂度: 这种方法不使用额外的数据结构,因此空间复杂度为 O(1)。
  • 替代方案: 对于性能要求较高的场景,更优化的方法是使用哈希表(HashMap<Character, Integer> 或 int[26] 数组用于小写英文字母)来记录每个字符的出现频率。这种方法通常具有 O(N) 的时间复杂度,因为它只需要对字符串进行一到两次遍历。

6. 总结

通过巧妙地组合使用 String 类的 charAt() 和 indexOf() 方法,我们可以实现查找字符串中第一个唯一字符的功能。核心在于利用 indexOf(char ch, int fromIndex) 方法从字符首次出现位置的下一个索引开始进行二次查找。如果二次查找返回 -1,则表明该字符是唯一的。尽管这种方法在简洁性上表现出色,但在处理极端长度的字符串时,应考虑其 O(N^2) 的时间复杂度,并根据实际需求权衡是否采用更高效的基于哈希表的解决方案。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1030

2023.08.02

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1567

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1228

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1204

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

193

2025.07.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11.2万人学习

Java 教程
Java 教程

共578课时 | 81万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号