《Python 程序设计》习题与参考答案
第1章基础知识
1.1简单说明如何选择正确的 答:
在选择Python的时候,一定要先考虑清楚自己学习 Python的目的是什么,打算做哪方面的开发,有哪些扩 展库可用,这些扩展库最高反复安装和卸载上。同时还应该注意,当更新的
新,而是应该等确定自己所必须使用的扩展库也推岀了较新版本之后再进行更新。
尽管如此,Python 3毕竟是大势所趋,如果您暂时还没想到要做什么行业领域的应用开发,或者仅仅是为 了尝试一种新的、好玩的语言,那么请毫不犹豫地选择
1.2为什么说Python采用的是基于值的内存管理模式? 答:
Python采用的是基于值的内存管理方式,如果为不同变量赋值相同值,则在内存中只有一份该值,多个变 量指向同一块内存地址,例如下面的代码。 >>> x = 3 >>> id(x) >>> y = 3 >>> id(y) >>> y = 5 >>> id(y) >>> id(x)
1.3在Python中导入模块中的对象有哪几种方式? 答:常用的有三种方式,分别为
import模块名[as别名]
Python 3.x系列的最高版本(目前是
Python 343 )。
Python版本推岀之后,不要急于更
Python版本。
from 模块名import对象名[as别名]
from math import *
1.4使用pip命令安装numpy、scipy模块。 答:在命令提示符环境下执行下面的命令:
pip in stall n umpy pip in stall scipy
1.5编写程序,用户输入一个三位以上的整数,输岀其百位以上的数字。例如用户输入 12。(提示:使用整除运算。)
答:
x = in put('Please in put an in teger of more tha n 3 digits:') try:
x = in t(x) x = x//100 if x == 0:
pri nt('You must in put an in teger of more tha n 3 digits.') else:
pri nt(x)
except BaseExcepti on:
prin t('You must in put an in teger.') import types
x = in put('Please in put an in teger of more tha n 3 digits:') if type(x) != types .In tType:
print 'You must in put an in teger.' elif le n( str(x)) != 4:
print 'You must in put an in teger of more tha n 3 digits.' else:
print x//100
1234,则程序输岀
第2章Python数据结构
2.1为什么应尽量从列表的尾部进行元素的增加与删除操作? 答:
当列表增加或删除元素时,列表对象自动进行内存扩展或收缩,从而保证元素之间没有缝隙,但这涉及到 列表元素的移动,效率较低,应尽量从列表尾部进行元素的增加与删除操作以提高处理速度。
2.2编写程序,生成包含 合。)
答: import ran dom
x = [ran dom.ra ndin t(0,100) for i in ran ge(1000)] d = set(x) for v in d:
prin t(v, ':', x.cou nt(v)) import ran dom
x = [ran dom.ra ndin t(0,100) for i in ran ge(1000)] d = set(x)
1000个0到100之间的随机整数,并统计每个元素的岀现次数。(提示:使用集
for v in d:
print v, ':', x.cou nt(v) 2.3编写程序,用户输入一个列表和
2个整数作为下标,然后输岀列表中介于
2个下标之间的元素组成的
子列表。例如用户输入 [1,2,3,4,5,6]和2,5,程序输岀[3,4,5,6]。
答:
x = in put('Please in put a list:') x = eval(x)
start, end = eval( in put('Please in put the start positi on and the end positi on:')) pri nt(x[start:e nd])
x = in put('Please in put a list:')
start, end = input('Please in put the start position and the end position:') pri nt x[start:e nd]
2.4设计一个字典,并编写程序,用户输入内容作为键,然后输岀字典中对应的值,如果用户输入的键不 存在,则输岀“您输入的键不存在!”
答:
d = {1:'a', 2:'b', 3:'c', 4:'d'} v = in put('Please in put a key:') v = eval(v)
print(d.get(v,'您输入的的键不存在 ’)) d = {1:'a', 2:'b', 3:'c', 4:'d'} v = in put('Please in put a key:') print(d.get(v,'您输入的的键不存在 ’))
2.5编写程序,生成包含 岀结果。
答: import ran dom
x = [ran dom .randin t(0,100) for i in ran ge(20)] pri nt(x) y = x[0:10]
y.sort() x[0:10] = y y = x[10:20] y.sort(reverse=True) x[10:20] = y pri nt(x) import ran dom
x = [ran dom .randin t(0,100) for i in ran ge(20)] pri nt x y = x[0:10] y.sort()
20个随机数的列表,然后将前
10个元素升序排列,后
10个元素降序排列,并输
x[0:10] = y y = x[10:20] y.sort(reverse=True) x[10:20] = y pri nt x
2.6在Python中,字典和集合都是用一对 和 值 ,其中 键
不允许重复。
大括号
作为定界符,字典的每个元素有两部分组成,即_键
2.7假设有列表a = ['name','age','sex']和b = ['Dong',38,'Male'],请使用一个语句将这两个列表的内容转换为字 典,并且以列表 a中的元素为键,以列表
2.8假设有一个列表 a,现要求从列表 用语句 b = a[::3]。
2.9使用列表推导式生成包含 2.10不可以
(可以、不可以)使用
10个数字5的列表,语句可以写为 [5 for i in range(10)]。 del命令来删除元组中的部分元素。
b中的元素为值,这个语句可以写为
c = dict(zip(a,b))。
b,可以使
a中每3个元素取1个,并且将取到的元素组成新的列表
第3章选择结构与循环结构
3.1分析逻辑运算符“ or”的短路求值特性。 答:
假设有表达式“表达式 1 or表达式2”,如果表达式1的值等价于True,那么无论表达式 整个表达式的值总是等价于
True。因此,不需要再计算表达式
2的值。
400整除,则为闰 2的值是什么,
3.2编写程序,运行后用户输入 4位整数作为年份,判断其是否为闰年。如果年份能被
年;如果年份能被 4整除但不能被100整除也为闰年。
答:
x = in put(卩 lease in put an in teger of 4 digits mea ning the year:') x = eval(x)
if x@0==0 or (x%4==0 and not x0==0):
prin t('Yes') else:
prin t('No')
x = in put('Please in put an in teger of 4 digits mea ning the year:') if x@0==0 or (x%4==0 and not x0==0):
print 'Yes' else:
print 'No'
3.3编写程序,生成一个包含
50个随机整数的列表,然后删除其中所有奇数。(提示:从后向前删。)
答: import ran dom
x = [ran dom .randin t(0,100) for i in ran ge(50)] pri nt(x) i = len( x)-1 while i>=0:
if x[i]%2==1:
del x[i] i-=1 pri nt(x)
把上面的代码中第三行和最后一行改为
print x即可。
34编写程序,生成一个包含 20个随机整数的列表,然后对其中偶数下标的元素进行降序排列,奇数下标的元素不变。(提示:使用切片。)
答: import ran dom
x = [ran dom .randin t(0,100) for i in ran ge(20)] pri nt(x) y = x[::2]
y.sort(reverse=True) x[::2] = y pri nt(x)
把上面的代码中第三行和最后一行改为
print x即可。
35编写程序,用户从键盘输入小于 1000的整数,对其进行因式分解。例如,
10=2 X 5,答:
x = in put('Please in put an in teger less tha n 1000:') x = eval('x') t = x i = 2 result =[] while True:
if t==1:
break if t%i==0:
result.appe nd(i) t = t/i else:
i+=1
Print x,'=','*'.joi n( map(str,result))
x = in put('Please in put an in teger less tha n 1000:')
60=2 X 2 X 3X 5