1、Python程序设计习题与参考答案第1章 基础知识1.1 简单说明如何选择正确的Python版本。答:在选择Python的时候,一定要先考虑清楚自己学习Python的目的是什么,打算做哪方面的开发,有哪些扩展库可用,这些扩展库最高支持哪个版本的Python,是Python 2.x还是Python 3.x,最高支持到Python 2.7.6还是Python 2.7.9。这些问题都确定以后,再做出自己的选择,这样才能事半功倍,而不至于把大量时间浪费在Python的反复安装和卸载上。同时还应该注意,当更新的Python版本推出之后,不要急于更新,而是应该等确定自己所必须使用的扩展库也推出了较新版本之
2、后再进行更新。尽管如此,Python 3毕竟是大势所趋,如果您暂时还没想到要做什么行业领域的应用开发,或者仅仅是为了尝试一种新的、好玩的语言,那么请毫不犹豫地选择Python 3.x系列的最高版本(目前是Python 3.4.3)。1.2 为什么说Python采用的是基于值的内存管理模式?答:Python采用的是基于值的内存管理方式,如果为不同变量赋值相同值,则在内存中只有一份该值,多个变量指向同一块内存地址,例如下面的代码。 x = 3 id(x)10417624 y = 3 id(y)10417624 y = 5 id(y)10417600 id(x)104176241.3 在Python
3、中导入模块中的对象有哪几种方式?答:常用的有三种方式,分别为l import 模块名 as 别名l from 模块名 import 对象名 as 别名l from math import *1.4 使用pip命令安装numpy、scipy模块。答:在命令提示符环境下执行下面的命令:pip install numpypip install scipy1.5 编写程序,用户输入一个三位以上的整数,输出其百位以上的数字。例如用户输入1234,则程序输出12。(提示:使用整除运算。)答:1)Python 3.4.2代码:x = input(Please input an integer of more
4、 than 3 digits:)try: x = int(x) x = x/100 if x = 0: print(You must input an integer of more than 3 digits.) else: print(x)except BaseException: print(You must input an integer.)2)Python 2.7.8代码:import typesx = input(Please input an integer of more than 3 digits:)if type(x) != types.IntType: print Yo
5、u must input an integer.elif len(str(x) != 4: print You must input an integer of more than 3 digits.else: print x/100第2章 Python数据结构2.1 为什么应尽量从列表的尾部进行元素的增加与删除操作?答:当列表增加或删除元素时,列表对象自动进行内存扩展或收缩,从而保证元素之间没有缝隙,但这涉及到列表元素的移动,效率较低,应尽量从列表尾部进行元素的增加与删除操作以提高处理速度。2.2 编写程序,生成包含1000个0到100之间的随机整数,并统计每个元素的出现次数。(提示:使用集
6、合。)答:1)Python 3.4.2代码import randomx = 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 randomx = random.randint(0,100) for i in range(1000)d = set(x)for v in d: print v, :, x.count(v)2.3 编写程序,用户输入一个列表和2个整数作为下标,然后输出列表中介于2个下标之间的元素组成的子列表。例如用户输
7、入1,2,3,4,5,6和2,5,程序输出3,4,5,6。答:1)Python 3.4.2代码x = input(Please input a list:)x = eval(x)start, end = eval(input(Please input the start position and the end position:)print(xstart:end)2)Python 2.7.8代码x = input(Please input a list:)start, end = input(Please input the start position and the end positi
8、on:)print xstart:end2.4 设计一个字典,并编写程序,用户输入内容作为键,然后输出字典中对应的值,如果用户输入的键不存在,则输出“您输入的键不存在!”答:1)Python 3.4.2代码d = 1:a, 2:b, 3:c, 4:dv = input(Please input a key:)v = eval(v)print(d.get(v,您输入的的键不存在)2)Python 2.7.8代码d = 1:a, 2:b, 3:c, 4:dv = input(Please input a key:)print(d.get(v,您输入的的键不存在)2.5 编写程序,生成包含20个随机
9、数的列表,然后将前10个元素升序排列,后10个元素降序排列,并输出结果。答:1)Python 3.4.2代码import randomx = random.randint(0,100) for i in range(20)print(x)y = x0:10y.sort()x0:10 = yy = x10:20y.sort(reverse=True)x10:20 = yprint(x)2)Python 2.7.8代码import randomx = random.randint(0,100) for i in range(20)print xy = x0:10y.sort()x0:10 = yy
10、 = x10:20y.sort(reverse=True)x10:20 = yprint x2.6 在Python中,字典和集合都是用一对 大括号 作为定界符,字典的每个元素有两部分组成,即 键 和 值 ,其中 键 不允许重复。2.7 假设有列表a = name,age,sex和b = Dong,38,Male,请使用一个语句将这两个列表的内容转换为字典,并且以列表a中的元素为键,以列表b中的元素为值,这个语句可以写为 c = dict(zip(a,b)。2.8 假设有一个列表a,现要求从列表a中每3个元素取1个,并且将取到的元素组成新的列表b,可以使用语句 b = a:3。2.9 使用列表推
11、导式生成包含10个数字5的列表,语句可以写为 5 for i in range(10)。2.10 不可以 (可以、不可以)使用del命令来删除元组中的部分元素。第3章 选择结构与循环结构3.1 分析逻辑运算符“or”的短路求值特性。答:假设有表达式“表达式1 or 表达式2”,如果表达式1的值等价于True,那么无论表达式2的值是什么,整个表达式的值总是等价于True。因此,不需要再计算表达式2的值。3.2 编写程序,运行后用户输入4位整数作为年份,判断其是否为闰年。如果年份能被400整除,则为闰年;如果年份能被4整除但不能被100整除也为闰年。答:1)Python 3.4.2代码x = in
12、put(Please input an integer of 4 digits meaning the year:)x = eval(x)if x%400=0 or (x%4=0 and not x%100=0): print(Yes)else: print(No)2)Python 2.7.8代码x = input(Please input an integer of 4 digits meaning the year:)if x%400=0 or (x%4=0 and not x%100=0): print Yeselse: print No3.3 编写程序,生成一个包含50个随机整数的列表
13、,然后删除其中所有奇数。(提示:从后向前删。)答:1)Python 3.4.2代码import randomx = random.randint(0,100) for i in range(50)print(x)i = len(x)-1while i=0: if xi%2=1: del xi i-=1print(x)2)Python 2.7.8代码把上面的代码中第三行和最后一行改为print x即可。34 编写程序,生成一个包含20个随机整数的列表,然后对其中偶数下标的元素进行降序排列,奇数下标的元素不变。(提示:使用切片。)答:1)Python 3.4.2代码import randomx =
14、 random.randint(0,100) for i in range(20)print(x)y = x:2y.sort(reverse=True)x:2 = yprint(x)2)Python 2.7.8代码把上面的代码中第三行和最后一行改为print x即可。35 编写程序,用户从键盘输入小于1000的整数,对其进行因式分解。例如,10=25,60=2235。答:1)Python 3.4.2代码x = input(Please input an integer less than 1000:)x = eval(x)t = xi = 2result = while True: if t=
15、1: break if t%i=0: result.append(i) t = t/i else: i+=1Print x,=,*.join(map(str,result)2)Python 2.7.8代码x = input(Please input an integer less than 1000:)t = xi = 2result = while True: if t=1: break if t%i=0: result.append(i) t = t/i else: i+=1print x,=,*.join(map(str,result)3.6 编写程序,至少使用2种不同的方法计算100以
16、内所有奇数的和。答:Python 3.4.2代码如下,如果使用Python 2.7.8只需要把其中的print()函数改为print语句即可。x = i for i in range(1,100) if i%2=1print(sum(x)print(sum(range(1,100):2)3.7 编写程序,实现分段函数计算,如下表所示。xyx000=x5x5=x103x-510=x200.5x-220=x0答:Python 3.4.2代码如下,如果使用Python 2.7.8只需要把其中的print()函数改为print语句即可。x = input(Please input x:)x = eva
17、l(x)if x=20: print(0)elif 0=x5: print(x)elif 5=x10: print(3*x-5)elif 10=x20: print(0.5*x-2)第4章 字符串与正则表达式4.1 假设有一段英文,其中有单独的字母“I”误写为“i”,请编写程序进行纠正。答:这里给出Python 3.4.2代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。1)不使用正则表达式x = i am a teacher,i am man, and i am 38 years old.I am not a businessman.x = x
18、.replace(i ,I )x = x.replace( i , I )print(x)2)使用正则表达式x = i am a teacher,i am man, and i am 38 years old.I am not a businessman.import repattern = pile(r(?:w|b)i(?:w)while True: result = pattern.search(x) if result: if result.start(0) != 0: x = x:result.start(0)+1+I+xresult.end(0)-1: else: x = x:res
19、ult.start(0)+I+xresult.end(0)-1: else: breakprint(x)4.2 假设有一段英文,其中有单词中间的字母“i”误写为“I”,请编写程序进行纠正。答:这里给出Python 3.4.2代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。import rex = I am a teacher,I am man, and I am 38 years old.I am not a busInessman.print(x)pattern = pile(r(?:w)I(?:w)while True: result =
20、pattern.search(x) if result: if result.start(0) != 0: x = x:result.start(0)+1+i+xresult.end(0)-1: else: x = x:result.start(0)+i+xresult.end(0)-1: else: breakprint(x)4.3 有一段英文文本,其中有单词连续重复了2次,编写程序检查重复的单词并只保留一个。例如文本内容为“This is is a desk.”,程序输出为“This is a desk.”答:这里给出Python 3.4.2代码,如果使用Python 2.7.8的话只需要
21、修改其中的print()函数为print语句即可。1)方法一import rex = This is a a desk.pattern = pile(rb(w+)(s+1)1,b)matchResult = pattern.search(x)x = pattern.sub(matchResult.group(1),x)print(x)2)方法二x = This is a a desk.pattern = pile(r(?Pbw+b)s(?P=f)matchResult = pattern.search(x)x = x.replace(matchResult.group(0),matchResu
22、lt.group(1)4.4 简单解释Python的字符串驻留机制。答:Python支持字符串驻留机制,即:对于短字符串,将其赋值给多个不同的对象时,内存中只有一个副本,多个对象共享该副本。这一点不适用于长字符串,即长字符串不遵守驻留机制,下面的代码演示了短字符串和长字符串在这方面的区别。 a = 1234 b = 1234 id(a) = id(b)True a = 1234*50 b = 1234*50 id(a) = id(b)False4.5 编写程序,用户输入一段英文,然后输出这段英文中所有长度为3个字母的单词。答:这里给出Python 3.4.2代码,如果使用Python 2.7.
23、8的话只需要修改其中的print()函数为print语句即可。import rex = input(Please input a string:)pattern = pile(rba-zA-Z3b)print(pattern.findall(x)第5章 函数设计与使用5.1 运行5.3.1小节最后的示例代码,查看结果并分析原因。答:原因是对于函数的默认值参数只会被处理一次,下次再调用函数并且不为默认值参数赋值时会继续使用上一次的结果,对于列表这样的结构,如果调用函数时为默认值参数的列表插入或删除了元素,将会得到保留,从而影响下一次调用。5.2 编写函数,判断一个整数是否为素数,并编写主程序调用
24、该函数。答:这里给出Python 3.4.2代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。import mathdef IsPrime(v): n = int(math.sqrt(v)+1) for i in range(2,n): if v%i=0: return No else: return Yesprint(IsPrime(37)print(IsPrime(60)print(IsPrime(113)5.3 编写函数,接收一个字符串,分别统计大写字母、小写字母、数字、其他字符的个数,并以元组的形式返回结果。答:这里给出Python 3.
25、4.2代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。def demo(v): capital = little = digit = other =0 for i in v: if A=i=Z: capital+=1 elif a=i=z: little+=1 elif 0=i def demo():a=3print a a=5 demo()3 a55.5 编写函数,可以接收任意多个整数并输出其中的最大值和所有整数之和。答:这里给出Python 3.4.2代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语
26、句即可。def demo(*v): print(v) print(max(v) print(sum(v)demo(1,2,3)demo(1,2,3,4)demo(1,2,3,4,5)5.6 编写函数,模拟内置函数sum()。答:这里给出Python 3.4.2代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。def Sum(v): s = 0 for i in v: s += i return sx = 1,2,3,4,5print(Sum(x)x = (1,2,3,4,5)print(Sum(x)5.7 编写函数,模拟内置函数sorted()。
27、答:这里给出Python 3.4.2代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。def Sorted(v): t = v: r = while t: tt = min(t) r.append(tt) t.remove(tt) return rx = 1,3,5,2,1,0,9,7print(x)print(Sorted(x)第6章 面向对象程序设计6.1 继承6.5节例2中的Person类生成Student类,填写新的函数用来设置学生专业,然后生成该类对象并显示信息。答:Python 3.4.2代码为import typesclass Pe
28、rson(object): #基类必须继承于object,否则在派生类中将无法使用super()函数 def _init_(self, name = , age = 20, sex = man): self.setName(name) self.setAge(age) self.setSex(sex) def setName(self, name): if not isinstance(name,str): print(name must be string.) return self._name = name def setAge(self, age): if not isinstance(
29、age,int): print(age must be integer.) return self._age = age def setSex(self, sex): if sex != man and sex != woman: print(sex must be man or woman) return self._sex = sex def show(self): print(self._name) print(self._age) print(self._sex)class Student(Person): def _init_(self, name=, age = 30, sex =
30、 man, major = Computer): #调用基类构造方法初始化基类的私有数据成员 super(Student, self)._init_(name, age, sex) self.setMajor(major) #初始化派生类的数据成员 def setMajor(self, major): if not isinstance(major, str): print(major must be a string.) return self._major = major def show(self): super(Student, self).show() print(self._maj
31、or)if _name_ =_main_: zhangsan = Person(Zhang San, 19, man) zhangsan.show() lisi = Student(Li Si,32, man, Math) lisi.show()6.2 设计一个三维向量类,并实现向量的加法、减法以及向量与标量的乘法和除法运算。答:Python 3.4.2代码如下class Vecter3: def _init_(self, x=0, y=0, z=0): self.X = x self.Y = y self.Z = z def _add_(self, n): r = Vecter3() r.X
32、 = self.X + n.X r.Y = self.Y + n.Y r.Z = self.Z + n.Z return r def _sub_(self, n): r = Vecter3() r.X = self.X - n.X r.Y = self.Y - n.Y r.Z = self.Z - n.Z return r def _mul_(self, n): r = Vecter3() r.X = self.X * n r.Y = self.Y * n r.Z = self.Z * n return r def _truediv_(self, n): r = Vecter3() r.X =
33、 self.X / n r.Y = self.Y / n r.Z = self.Z / n return r def _floordiv_(self, n): r = Vecter3() r.X = self.X / n r.Y = self.Y / n r.Z = self.Z / n return r def show(self): print(self.X,self.Y,self.Z)v1 = Vecter3(1,2,3)v2 = Vecter3(4,5,6)v3 = v1+v2v3.show()v4 = v1-v2v4.show()v5 = v1*3v5.show()v6 = v1/2
34、v6.show()6.3 面向对象程序设计的三要素分别为 封装 、 继承 和 多态 。6.4 简单解释Python中以下划线开头的变量名特点。答:在Python中,以下划线开头的变量名有特殊的含义,尤其是在类的定义中。用下划线作为变量前缀和后缀来表示类的特殊成员:l _xxx:这样的对象叫做保护变量,不能用from module import *导入,只有类对象和子类对象能访问这些变量;l _xxx_:系统定义的特殊成员名字;l _xxx:类中的私有成员,只有类对象自己能访问,子类对象也不能访问到这个成员,但在对象外部可以通过“对象名._类名_xxx”这样的特殊方式来访问。Python中没有纯
35、粹的C+意义上的私有成员。6.5 与运算符“*”对应的特殊方法名为 _pow_() ,与运算符“/”对应的特殊方法名为 _floordiv_() 。第7章 文件操作7.1 假设有一个英文文本文件,编写程序读取其内容,并将其中的大写字母变为小写字母,小写字母变为大写字母。答:f = open(rd:1.txt,r)s = f.readlines()f.close()r = i.swapcase() for i in sf = open(rd:2.txt,w)f.writelines(r)f.close()7.2 编写程序,将包含学生成绩的字典保存为二进制文件,然后再读取内容并显示。答:Pytho
36、n 3.4.2代码import pickled = 张三:98,李四:90,王五:100print(d)f = open(score.dat,wb)pickle.dump(1,f)pickle.dump(d,f)f.closef = open(score.dat,rb)pickle.load(f)d = pickle.load(f)f.close()print(d)7.3 使用shutil模块中的move()方法进行文件移动。答: import shutil shutil.move(rd:1.txt, re:1.txt)e:1.txt7.4 简单解释文本文件与二进制文件的区别。答:(1)文本文
37、件文本文件存储的是常规字符串,由若干文本行组成,通常每行以换行符n结尾。常规字符串是指记事本或其他文本编辑器能正常显示、编辑并且人类能够直接阅读和理解的字符串,如英文字母、汉字、数字字符串。文本文件可以使用字处理软件如gedit、记事本进行编辑。(2)二进制文件二进制文件把对象内容以字节串(bytes)进行存储,无法用记事本或其他普通字处理软件直接进行编辑,通常也无法被人类直接阅读和理解,需要使用专门的软件进行解码后读取、显示、修改或执行。常见的如图形图像文件、音视频文件、可执行文件、资源文件、各种数据库文件、各类office文档等都属于二进制文件。7.5 编写代码,将当前工作目录修改为“c:
38、”,并验证,最后将当前工作目录恢复为原来的目录。答: import os os.getcwd()C:Python34 os.chdir(rc:) os.getcwd()c: os.chdir(rc:Python34) os.getcwd()c:Python347.6 编写程序,用户输入一个目录和一个文件名,搜索该目录及其子目录中是否存在该文件。答:1)Python 3.4.2代码import sysimport osdirectory = sys.argv1filename = sys.argv2paths = os.walk(directory)for root,dirs,files in
39、paths: if filename in files: print(Yes) breakelse: print(No)2)Python 2.7.8代码import sysimport osdirectory = sys.argv1filename = sys.argv2paths = os.walk(directory)for root,dirs,files in paths: if filename in files: print Yes breakelse: print No第8章 异常处理结构与程序调试8.1 Python异常处理结构有哪几种形式?答:比较常用的形式有:1)标准异常处理
40、结构try:try块 #被监控的语句,可能会引发异常except Exception, reason:except块 #处理异常的代码如果需要捕获所有异常时,可以使用BaseException,代码格式如下:try:except BaseException, e: except块#处理所有错误 上面的结构可以捕获所有异常,尽管这样做很安全,但是一般并不建议这样做。对于异常处理结构,一般的建议是尽量显式捕捉可能会出现的异常并且有针对性地编写代码进行处理,因为在实际应用开发中,很难使用同一段代码去处理所有类型的异常。当然,为了避免遗漏没有得到处理的异常干扰程序的正常执行,在捕捉了所有可能想到的异常之后,您也可以使用异常处理结构的最后一个except来捕捉BaseException。2)另外一种常用的异常处理结