第2章Python序列
2.1 为什么应尽量从列表的尾部进行元素的增加与删除操作?
答:
当列表增加或删除元素时,列表对象自动进行内存扩展或收缩,从而保证元素之间没有缝隙,但这涉及到列表元素的移动,效率较低,应尽量从列表尾部进行元素的增加与删除操作以提高处理速度。
2.2 range()函数在Python 2.x中返回一个包含整数的列表,而Python
3.x的range()函数返回一个可迭代的range对象。
2.3 编写程序,生成包含1000个0到100之间的随机整数,并统计每个元素的出现次数。
答:可以使用集合来实现该功能。
1)Python 3.4.2代码
import random
x = [random.randint(0,100) for i in range(1000)]
d = set(x)
for v in d:
print(v, ':', x.count(v))
2)Python 2.7.8代码
import random
x = [random.randint(0,100) for i in range(1000)]
d = set(x)
for v in d:
print v, ':', x.count(v)
也可以直接使用字典来实现该功能,并且获得更高的执行效率,例如下面的Python 3.4.2代码:
listRandom = [random.randint(1,100) for i in range(1000000)]
d = dict()
start = time.time()
for i in listRandom: #对随机数列表扫描一次,即可得到结果
d[i] = d.get(i,0)+1
print(time.time()-start)
2.4 表达式“[3] in [1, 2, 3, 4]”的值为False 。
2.5 编写程序,用户输入一个列表和2个整数作为下标,然后输出列表中介于2个下标