零py-(ep-13)
本帖最后由 Nicole37 于 2023-8-7 12:32 编辑列表4:
加法:将两个列表进行拼接
乘法:将列表中的元素重复x次
a = ["today","is","friday"]
b = ["let","us","have","fun"]
a+b
['today', 'is', 'friday', 'let', 'us', 'have', 'fun']
a*3
['today', 'is', 'friday', 'today', 'is', 'friday', 'today', 'is', 'friday']
嵌套列表(二维列表):在列表中嵌套列表;可用于“举证”
c = [,]
c
[, ]
访问嵌套列表:
用嵌套循环来访问:
for i in c:
for j in i:
print(j)
1
2
3
5
6
9
for i in c:
for j in i:
print(j,end = ' ') #print语句默认是自动换行的,加了end以后,输出的数据不会自动换行,而是取决于end里面的空格数
print() #遍历一遍j以后,换行
1 2 3
5 6 9
用下标索引来访问:
c #第一个下标表示取出c的下标为0的元素为,第二个下标表示取出中的下标为2的元素
3
用循环语句创建并初始化循环列表:
e = #想创建一个3个元素的嵌套列表,先将列表初始化3个元素
for i in range(3): #循环3次,每次都让e的元素为一个列表
e = *3
e
[, , ]
注意:python在idle中只能一句一句编译,故不能将所有段落直接复制,一句一句复制/在文件里运行
is运算符:同一性运算符,用于检验两个变量是否指向同一个运算符
x = "yuanjiyunjiao"
y = "yuanjiyunjiao"
x is y #is用来比较两个变量是否指向同一个运算符 字符串在python的内存空间是固定的,只开辟一个空间存放该字符串(仅限于英文字母)
True
p =
q =
p is q #列表在python中占据不同的地址内存,即使列表的内容一样,所占的位置也是不同的
False
注意:用循环嵌套和乘法 两种方法所构造出的嵌套列表是不同的
a =
for i in range(3):
a = *3
a
[, , ]
b = [*3]*3 #b这种构造方法 只是对同一个列表进行3次调用,并没有开辟3个内存空间存放每个元素
b
[, , ]
b is b
True
b is b #判断b的两个元素是否内存位置相同
True
a is a #由于a是正常构造嵌套列表,其两个元素列表所占的位置是不同的
False
作业:
1、建立三维列表(我):
a = *3
b = *3
for i in range(3):
b = *3
for j in range(3):
a = ]*3
a
[[, , ], [, , ], [, , ]]
2、根据内存关系画图(我):
x = [*3]*3
x
[, , ]
y = *3
for i in range(3):
y = *3
y
[, , ]
z = *3
p = *2
for i in range(2):
p = *2
for j in range(3):
z = ]*3
z
[[, , ], [, , ], [, , ]]
z = * 3#方法二
for i in range(3):
z = * 3
for j in range(3):
z = * 2
3、 a = 250
b = 250
a is b
True
a = 1000
b = 1000
a is b
False
出于性能优化方面的考虑,Python 在内部为 -5~256 范围内的整数维护了一个数组,起到缓存的作用,每次你试图创建一个 -5~256 范围内的整数时,Python 都会从这个数组中返回相对应的引用,而不是重新开辟一块新的内存空间存放。如果超过了 -5~256 这个范围(大家可以自己动手测试一下),比如 1000,那么 Python 会为两个 1000 单独开辟两块不同的内存区域,因此 a is b 的结果为 False
4、利用“摩尔投票法”来找出占比数量最多的两个元素(注意:这两个元素的数量都需要超过总数的三分之一)
nums =
major1 = major2 = nums #分别给第一和第二的两个初始化为nums
count1 = count2 = 0 #初始化他们的计数值都为0
# 对抗阶段
for each in nums:
if major1 == each: #并列判断两个major,优先判断major1,如果遍历的元素等于major则,count值加一,之后continue退出后面的左右步骤,为了避免影响到major2,
count1 += 1
continue
if major2 == each:
count2 += 1
continue
if count1 == 0: #当发现count1的值为0,即加加减减抵消掉了,则更新major1的值为当前遍历的元素值,并赋其初始计数值为1
major1 = each
count1 = 1
continue
if count2 == 0: #当发现count2的值为0,即加加减减抵消掉了,或者是each既不是major1也不是major2,并且此时major的计数值不为零,major1在正常迭代,则major2需要换新值,并赋其初始计数值为1
major2 = each
count2 = 1
continue
count1 -= 1 #当上述条件均不符合,即major1和major2都在正常的判断加加减减中,则each不等于二者,所以计数值减一
count2 -= 1
# 统计阶段
if nums.count(major1) > len(nums) / 3:
print(major1)
if nums.count(major2) > len(nums) / 3:
print(major2)
不理解的时候画图,模拟计算机的操作流程
此图出自?:
https://www.bilibili.com/video/BV1HT4y1K7DY 不二如是 发表于 2023-8-7 16:12
此图出自?:
不是这个视频,但是是小师妹一个系列滴
页:
[1]