Python教程:字符串中的第一个唯一字符

简介: Python教程:字符串中的第一个唯一字符

Python教程——字符串中的第一个唯一字符

题目:

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

案例:

s = "leetcode"

返回 0.

s = "loveleetcode",

返回 2.
注意事项:您可以假定该字符串只包含小写字母。

解题思路:

​ 很简单的题,无非就是对字符串的字母进行频率统计,找到出现频率为1 的字母索引。

​ 借助哈希映射两次遍历完成。第一次遍历进行字母频率统计,Hash Map 的Key 为字母,Value 为出现频率。第二次遍历找到频率为 1 的字母索引返回即可。

​ 不同于单词频率统计,字母一共只有 26 个,所以可以直接利用 ASii 码表里小写字母数值从 97~122,直接用 int 型数组映射。建立映射:索引为 小写字母的 ASii 码值,存储值为出现频率。

哈希映射解题:

Java:

class Solution {

public int firstUniqChar(String s) {

char[] chars = s.toCharArray();//转成 Char 数组

Map map = new HashMap<>();

for (Character c: chars) map.put(c, map.getOrDefault(c, 0) + 1);//频率统计

for (int i = 0; i < chars.length; i++) {

if(map.get(chars[i])==1) return i;//找到词频为1的字母(只出现一次)返回其索引

}

return -1;

}

}
Python:

class Solution:

def firstUniqChar(self, s):

count = collections.Counter(s)# 该函数就是Python基础库里词频统计的集成函数

index = 0

for ch in s:

if count[ch] == 1:

return index

else:

index += 1

return -1
数组映射解题:

Java:

class Solution {

public int firstUniqChar(String s) {

char[] chars = s.toCharArray();

int base = 97;

int[] loc = new int[26];

for (char c:chars) loc[c - base] += 1;

for (int i = 0; i < chars.length; i++) {

if(loc[chars[i]-base]==1) return i;

}

return -1;

}

}
Python 基础数据结构里没有 char 型,强行使用chr(i)转换,只会导致效率更低

Python教程:字符串中的第一个唯一字符
字符串函数解题:

Java:

利用 Java 字符串集成操作函数解题,很巧妙,效率也很高。

其中:

indexOf(): 返回该元素第一次出现的索引,没有则返回 -1

lastIndex(): 返回该元素最后一次出现的索引,没有则返回 -1

class Solution {

public int firstUniqChar(String s) {

int res = s.length();

for (int i = 'a'; i <= 'z'; i++) {

int firstIndex = s.indexOf((char)i);

if (firstIndex == -1) continue;

int lastIndex = s.lastIndexOf((char)i);

if (firstIndex == lastIndex) {//两次索引值相同则证明该字母只出现一次

res = Math.min(firstIndex, res);//res 为只出现一次的字母中索引值最小的

}

}

return res == s.length() ? -1 : res;

}

}
大家有什么意见的或者建议欢迎留言指出!更多的Python教程也会继续为大家更新!大家有需要学习课程的也可以岫岩或者私信!

相关文章
|
27天前
|
JSON 数据可视化 API
Python 中调用 DeepSeek-R1 API的方法介绍,图文教程
本教程详细介绍了如何使用 Python 调用 DeepSeek 的 R1 大模型 API,适合编程新手。首先登录 DeepSeek 控制台获取 API Key,安装 Python 和 requests 库后,编写基础调用代码并运行。文末包含常见问题解答和更简单的可视化调用方法,建议收藏备用。 原文链接:[如何使用 Python 调用 DeepSeek-R1 API?](https://apifox.com/apiskills/how-to-call-the-deepseek-r1-api-using-python/)
|
9天前
|
索引 Python
python字符串类型及操作
本文主要讲解字符串类型的表示、操作符、处理函数、处理方法及格式化。内容涵盖字符串的定义、表示方法(单双引号、三引号)、索引与切片、特殊字符转义、常见操作符(如+、*、in等)、处理函数(如len()、str()、chr()等)、处理方法(如.lower()、.split()等)以及格式化方式(如.format())。通过实例代码详细介绍了字符串的各种用法和技巧,帮助读者全面掌握字符串操作。
python字符串类型及操作
|
7天前
|
大数据 开发者 C++
Python语法糖详解教程
《Python语法糖详解教程》介绍了编程语言中的“语法糖”,即通过特殊语法形式简化代码,使代码更简洁、易读和高效。文章详细解析了列表推导式、字典推导式、元组解包、条件表达式、with语句和装饰器等核心语法糖,并提供了具体示例和最佳实践指南。通过这些技巧,开发者可以在保持底层功能不变的前提下,显著提升开发效率和代码质量。
29 8
|
2月前
|
IDE 测试技术 项目管理
【新手必看】PyCharm2025 免费下载安装配置教程+Python环境搭建、图文并茂全副武装学起来才嗖嗖的快,绝对最详细!
PyCharm是由JetBrains开发的Python集成开发环境(IDE),专为Python开发者设计,支持Web开发、调试、语法高亮、项目管理、代码跳转、智能提示、自动完成、单元测试和版本控制等功能。它有专业版、教育版和社区版三个版本,其中社区版免费且适合个人和小型团队使用,包含基本的Python开发功能。安装PyCharm前需先安装Python解释器,并配置环境变量。通过简单的步骤即可在PyCharm中创建并运行Python项目,如输出“Hello World”。
342 13
【新手必看】PyCharm2025 免费下载安装配置教程+Python环境搭建、图文并茂全副武装学起来才嗖嗖的快,绝对最详细!
|
9天前
|
C语言 Python
Python学习:内建属性、内建函数的教程
本文介绍了Python中的内建属性和内建函数。内建属性包括`__init__`、`__new__`、`__class__`等,通过`dir()`函数可以查看类的所有内建属性。内建函数如`range`、`map`、`filter`、`reduce`和`sorted`等,分别用于生成序列、映射操作、过滤操作、累积计算和排序。其中,`reduce`在Python 3中需从`functools`模块导入。示例代码展示了这些特性和函数的具体用法及注意事项。
|
2月前
|
存储 人工智能 Python
[oeasy]python061_如何接收输入_input函数_字符串_str_容器_ 输入输出
本文介绍了Python中如何使用`input()`函数接收用户输入。`input()`函数可以从标准输入流获取字符串,并将其赋值给变量。通过键盘输入的值可以实时赋予变量,实现动态输入。为了更好地理解其用法,文中通过实例演示了如何接收用户输入并存储在变量中,还介绍了`input()`函数的参数`prompt`,用于提供输入提示信息。最后总结了`input()`函数的核心功能及其应用场景。更多内容可参考蓝桥、GitHub和Gitee上的相关教程。
28 0
|
3月前
|
数据可视化 DataX Python
Seaborn 教程-绘图函数
Seaborn 教程-绘图函数
101 8
|
3月前
Seaborn 教程-主题(Theme)
Seaborn 教程-主题(Theme)
163 7
|
3月前
|
Python
Seaborn 教程-模板(Context)
Seaborn 教程-模板(Context)
60 4
|
3月前
|
数据可视化 Python
Seaborn 教程
Seaborn 教程
69 5

热门文章

最新文章