【Python】知识点零碎学习4

ord()函数

ord():以一个字符作为参数,返回ASCII码值

TypeError: unsupported operand type(s) for -: 'str' and 'str'

python不支持两个字符串直接做减法运算

例:

复制代码
ss[s[i]-'a']+=1#s[i]='b'

这样会报错,s[i] 是单个字符的字符串,'a' 也是字符串,python仅允许数字之间的减法。

正确的做法是: 先用 ord() 函数将字符转换为对应的 ASCII 码(整数),再做减法运算(比如 ord('a') 返回 97,ord('b') 返回 98

复制代码
ss[ord(s[i])-ord('a')]+=1

前缀和

前缀和的长度为n+1,第一个是s[0]=0


deque()

collections.deque()

可以在两端插入删除元素的队列

复制代码
deque=collections.deque()
deque.append(5)#在右端插入元素
deque.appendleft(5)#在左端插入元素
p=deque.pop(4)#在右端删除元素,并返回该值
p=deque.popleft(4)#在左端删除元素,并返回该值

Counter()

counter是字典的子类,key为待计数的元素, value为对应元素出现的次数 count。

虽然 Counter 中的 count 表示的是计数,但是 Counter 允许 count 的值为 0 或者负值。

如果在 Counter 中查找一个不存在的元素,不会产生异常,而是会返回 0

复制代码
from collections import Counter
a=Counter("chenkc")#Counter({'c': 2, 'h': 1, 'e': 1, 'n': 1, 'k': 1})

列表浅拷贝

python中"="对于列表来说是引用赋值,而不是创建新对象。新对象和原列表指向同一格内存对象。

指向不同对象的方法:

复制代码
new=old[:]
new=list(old)
new=copy.copy(old)

查询平均时间复杂度

列表:i in nums是O(n)时间复杂度

集合:i in nums是O(1)时间复杂度

字典:i in dic是查键,O(1)时间复杂度;i in dic.values()是查值,O(n)时间复杂度

元组:i in tup是O(n)时间复杂度


二维列表初始化

错误样例:[[值]*列数]*行数 初始化,但这会导致所有行指向同一个列表对象,修改任意一行的元素,其他行都会同步变化。

复制代码
# 试图初始化一个2行3列的二维列表,元素全为0
wrong_2d = [[0] * 3] * 2
print("初始化后:", wrong_2d)  # 输出: [[0, 0, 0], [0, 0, 0]]

# 修改第一行第一个元素
wrong_2d[0][0] = 1
print("修改后:", wrong_2d)  # 输出: [[1, 0, 0], [1, 0, 0]] → 第二行也被改了!

正确:

嵌套

复制代码
rows = 2
cols = 3
correct_2d = [[0 for _ in range(cols)] for _ in range(rows)]
print("初始化后:", correct_2d)  # [[0, 0, 0], [0, 0, 0]]

二分查找

bisect_left是在已排序的列表中找到指定元素的位置,返回第一个大于等于该元素的索引,保证能让目标元素插入后仍保持列表有序的位置。

bisect和bisect_right的功能一样,返回第一个大于该元素的索引

是基于二分查找算法实现的(时间复杂度 O (log n))

复制代码
bisect.bisect_left(a, x, lo=0, hi=len(a))
  • a:必须是升序排列的列表;
  • x:要查找 / 插入的目标元素;
  • lo(可选):查找的起始位置,默认 0;
  • hi(可选):查找的结束位置,默认列表长度。
相关推荐
冷雨夜中漫步7 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴7 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再7 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
盐焗西兰花8 小时前
鸿蒙学习实战之路-Reader Kit修改翻页方式字体大小及行间距最佳实践
学习·华为·harmonyos
颜酱8 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
QiZhang | UESTC8 小时前
学习日记day76
学习
久邦科技8 小时前
20个免费电子书下载网站,实现电子书自由(2025持续更新)
学习
m0_736919108 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi9878389 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab
喵手9 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控