网站首页 > java教程 正文
问题描述
下面是有关这个问题的描述部分。
英文
Given a string s, return the first non-repeating character in it and return its index. If it does not exist, return -1.
中文
针对给定的一个字符串 s,你需要写一个算法,返回给定字符串中不重复字符的位置(index),如果所有的字符在给定的字符串中都有重复的话,那么你应该返回 -1。
样例
下面给出了这个问题的示例,以便于你参考。
Input: s = “comossez” | 0 |
Input: s = “lovelycomossez” | 2 |
Input: s = “aabb” | -1 |
思路点评和源代码
整体来说这个题目的难度并不大。
有很多种解题的思路,首先你需要把字符串拆开放到数组中,这样你才能够一个字符一个字符的进行遍历。
我的这个思路肯定不是效率最高的,我的思路就是将字符串放到数组中,然后对数组进行遍历,在这个过程的同时还定义一个 Map,在这个 Map 中存储的 Key 就是正在查找的字符串,如果当前字符串在 Map 中没有的话,就 Put 进去。
Put 进行的 Key 是当前的字符串,值是当前字符串所在数组的下标。
如果当前字符串已经在 Map 中有的了话,我们可以修改 Map 的值为 2#5 这样的方式,中间可以使用 # 号或者任意特殊字符。
当完成上面的遍历后,我们就获得了需要的 map 了。
然后再对 Map 进行遍历,找到第一个不含有 # 号的值就行了。
为了进行有序存储,我们需要使用 LinkedHashMap,因为 HashMap 是无序的,无序的 Map 会把找到第一个的输入顺序弄错。
上图是对内存进行分析后,可以看到初始化后的 Map 的值。
代码
请访问 GitHub:
https://github.com/cwiki-us-docs/java-tutorials/blob/master/toolkits/codebank/src/test/java/com/ossez/toolkits/codebank/tests/leetcode/LeetCode0387FirstUniqueCharacterTest.java
猜你喜欢
- 2025-06-24 吊打面试官(十五)--Java语言中HashMap类一文全掌握
- 2025-06-24 Java集合隐藏的秒杀技巧!HashMap遍历竟比ArrayList快?(附代码)
- 2025-06-24 2021年Java小白该如何学习Java?(java应该怎么学)
- 2025-06-24 Java代码暗藏性能刺客!3个坑让你的程序慢10倍(附排查工具)
- 2025-06-24 Java 读取 xml 文件的五种方式(java读取xml中文乱码)
- 2025-06-24 二叉树的遍历(二叉树的遍历代码)
- 2025-06-24 Java中的枚举类型及其高级用法(java枚举类怎么用)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)