Python day-Dictionary,使用嵌套循环的字符频率

python day-dictionary,使用嵌套循环的字符频率

Python字典:高效存储数据

字典({})是一种强大的数据结构,用于存储键值对。它是有序的、可变的,且键值不允许重复。 每个元素都通过唯一的键来访问,而不是索引。如果尝试访问字典中不存在的键,则会引发KeyError异常。

示例:

thisdict = {  "brand": "Ford",  "model": "Mustang",  "year": 1964}student = {"name": "Raja", "class": 5}print(thisdict)print(student)

输出:

立即学习“Python免费学习笔记(深入)”;

{'brand': 'Ford', 'model': 'Mustang', 'year': 1964}{'name': 'Raja', 'class': 5}

练习:使用嵌套循环进行字符串字符频率分析

以下练习展示如何使用Python字典和循环来统计字符串中字符的频率,并解决一些相关的字符统计问题。 注意,为了提高效率,实际应用中应优先使用Python内置的Counter对象。

1. 统计每个字母的频率:

s = 'guruprasanna'char_counts = {}for char in s:    char_counts[char] = char_counts.get(char, 0) + 1for char, count in char_counts.items():    print(char, count)

输出:

立即学习“Python免费学习笔记(深入)”;

g 1u 2r 2p 1a 3s 1n 2

2. 仅列出出现一次的字母:

s = 'guruprasanna'char_counts = {}for char in s:    char_counts[char] = char_counts.get(char, 0) + 1for char, count in char_counts.items():    if count == 1:        print(char, count)

输出:

立即学习“Python免费学习笔记(深入)”;

g 1p 1s 1

3. 找出出现频率最高的字母:

s = 'guruprasanna'char_counts = {}for char in s:    char_counts[char] = char_counts.get(char, 0) + 1max_char = max(char_counts, key=char_counts.get)max_count = char_counts[max_char]print(max_char, max_count)

输出: (可能有多个字符频率相同,输出其中一个)

a 3

4. 找出第一个不重复的字母:

s = 'guruprasanna'char_counts = {}for char in s:    if char not in char_counts:        char_counts[char] = 0    char_counts[char] += 1for char in s:    if char_counts[char] == 1:        print(char)        break

输出:

立即学习“Python免费学习笔记(深入)”;

g

5. 找出第一个重复的字母:

s = 'guruprasanna'char_counts = set()for char in s:    if char in char_counts:        print(char)        break    char_counts.add(char)

输出:

立即学习“Python免费学习笔记(深入)”;

u

6. 找出最后一个不重复的字母:

s = 'guruprasanna'char_counts = {}for char in s:    char_counts[char] = char_counts.get(char, 0) + 1for char in reversed(s):    if char_counts[char] == 1:        print(char)        break

输出:

立即学习“Python免费学习笔记(深入)”;

s

7. 找出最后一个重复的字母:

s = 'guruprasanna'char_counts = {}for char in s:    char_counts[char] = char_counts.get(char, 0) + 1for char in reversed(s):    if char_counts[char] > 1:        print(char)        break

输出:

立即学习“Python免费学习笔记(深入)”;

n

8. 找出出现频率最高的字母 (改进版,处理多个频率最高的字符):

from collections import Counters = 'guruprasanna'char_counts = Counter(s)max_count = max(char_counts.values())most_common = [char for char, count in char_counts.items() if count == max_count]print(most_common, max_count)

输出:

立即学习“Python免费学习笔记(深入)”;

['a'] 3

9. 统计元音 (a, e, i, o, u) 的出现频率:

vowels = "aeiou"s = 'guruprasanna'vowel_counts = {}for char in s:    if char in vowels:        vowel_counts[char] = vowel_counts.get(char, 0) + 1for vowel, count in vowel_counts.items():    print(vowel, count)

输出:

立即学习“Python免费学习笔记(深入)”;

u 2a 3

这些例子展示了如何使用Python字典和循环来有效地处理字符频率统计问题。 记住,对于大型数据集,collections.Counter 提供了更简洁和高效的解决方案。

以上就是Python day-Dictionary,使用嵌套循环的字符频率的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1355282.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 19:08:57
下一篇 2025年12月13日 19:09:07

相关推荐

发表回复

登录后才能评论
关注微信