《Python程序设计基础习题复习资料与分析课件.docx》由会员分享,可在线阅读,更多相关《Python程序设计基础习题复习资料与分析课件.docx(28页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Python程序设计基础习题答案及分析程昱第1章 基础知识1.1 简单说明如何选择正确的Python版本。答:在选择Python的时候,一定要先考虑清楚自己学习Python的目的是什么,打算做哪方面的开发,有哪些扩展库可用,这些扩展库最高支持哪个版本的Python,是Python 2.x还是Python 3.x,最高支持到Python 还是Python 2.7.9。这些问题都确定以后,再做出自己的选择,这样才能事半功倍,而不至于把大量时间浪费在Python的反复安装与卸载上。同时还应该注意,当更新的Python版本推出之后,不要急于更新,而是应该等确定自己所必须使用的扩展库也推出了较新版本之后
2、再进行更新。尽管如此,Python 3毕竟是大势所趋,如果您暂时还没想到要做什么行业领域的应用开发,或者仅仅是为了尝试一种新的、好玩的语言,那么请毫不犹豫地选择Python 3.x系列的最高版本(目前是Python )。1.2 为什么说Python采用的是基于值的内存管理模式?Python采用的是基于值的内存管理方式,如果为不同变量赋值相同值,则在内存中只有一份该值,多个变量指向同一块内存地址,例如下面的代码。 x = 3 id(x) y = 3 id(y) y = 5 id(y) id(x) x = 1, 2, 3, 1, 1, 2 id(x0)=id(x3)=id(x4)True1.3 解
3、释Python中的运算符“/”与“/”的区别。答:在Python 2.x中,“/”为普通除法,当两个数值对象进行除法运算时,最终结果的精度及操作数中精度最高的一致;在Python 3.x中,“/”为真除法,及除法的数学含义一致。在Python 2.x与Python 3.x中,“/”表示整除,对整数或浮点数进行该运算时,结果为数学除法的整数部分。1.4 在Python中导入模块中的对象有哪几种方式?答:常用的有三种方式,分别为l import 模块名 as 别名l from 模块名 import 对象名 as 别名l from math import *1.5 pip 是目前比较常用的Pytho
4、n扩展库管理工具。1.6 解释Python脚本程序的“_name_”变量及其作用。答:每个Python脚本在运行时都有一个“_name_”属性。如果脚本作为模块被导入,则其“_name_”属性的值被自动设置为模块名;如果脚本独立运行,则其“_name_”属性值被自动设置为“_main_”。利用“_name_”属性即可控制Python程序的运行方式。1.7 运算符“%” 可以 (可以、不可以)对浮点数进行求余数操作。1.8 一个数字“5” 是 (是、不是)合法的Python表达式。1.9 在Python 2.x中,input()函数接收到的数据类型由 界定符 字符串 。1.10 编写程序,用户输
5、入一个三位以上的整数,输出其百位以上的数字。例如用户输入1234,则程序输出12。(提示:使用整除运算。)答:1)Python 代码:x = input(Please input an integer of more 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 代码:imp
6、ort typesx = input(Please input an integer of more than 3 digits:)if type(x) != types.IntType: print You 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 为什么应尽量从列表的尾部进行元素的增加及删除操作?答:当列表增加或删除元素时,列表对象自动进行内存扩展或收缩,从而保证元素之间没
7、有缝隙,但这涉及到列表元素的移动,效率较低,应尽量从列表尾部进行元素的增加及删除操作以提高处理速度。 包含整数的列表 ,而Python 3.x的range()函数返回一个 可迭代的range对象 。2.3 编写程序,生成包含1000个0到100之间的随机整数,并统计每个元素的出现次数。答:可以使用集合来实现该功能。1)Python 代码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 代码import randomx =
8、random.randint(0,100) for i in range(1000)d = set(x)for v in d:print v, :, x.count(v)也可以直接使用字典来实现该功能,并且获得更高的执行效率,例如下面的Python 代码:listRandom = random.randint(1,100) for i in range(1000000)d = dict()start = time.time()for i in listRandom: #对随机数列表扫描一次,即可得到结果 di = d.get(i,0)+1print(time.time()-start)2.4
9、表达式“3 in 1, 2, 3, 4”的值为 False 。2.5 编写程序,用户输入一个列表与2个整数作为下标,然后输出列表中介于2个下标之间的元素组成的子列表。例如用户输入1, 2, 3, 4, 5, 6与2,5,程序输出3, 4, 5, 6。答:1)Python 代码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 代码x = input(Plea
10、se input a list:)start, end = input(Please input the start position and the end position:)print xstart:end2.6 列表对象的sort()方法用来对列表元素进行原地排序,该函数返回值为 None 。2.7 列表对象的 remove() 方法删除首次出现的指定元素,如果列表中不存在要删除的元素,则抛出异常。2.8 假设列表对象aList的值为3, 4, 5, 6, 7, 9, 11, 13, 15, 17,那么切片aList3:7得到的值是 6, 7, 9, 11 。2.9 设计一个字典,并编
11、写程序,用户输入内容作为“键”,然后输出字典中对应的“值”,如果用户输入的“键”不存在,则输出“您输入的键不存在!”答:1)Python 代码d = 1:a, 2:b, 3:c, 4:dv = input(Please input a key:)v = eval(v)print(d.get(v,您输入的的键不存在)2)Python 代码d = 1:a, 2:b, 3:c, 4:dv = input(Please input a key:)print(d.get(v,您输入的的键不存在)2.10 编写程序,生成包含20个随机数的列表,然后将前10个元素升序排列,后10个元素降序排列,并输出结果。
12、答:1)Python 代码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 代码import randomx = random.randint(0,100) for i in range(20)print xy = x0:10y.sort()x0:10 = yy = x10:20y.sort(reverse=True)x10:20 = yprint x
13、2.11 在Python中,字典与集合都是用一对 大括号 作为界定符,字典的每个元素有两部分组成,即 “键” 与 “值” ,其中 “键” 不允许重复。2.12 使用字典对象的 items() 方法可以返回字典的“键-值对”列表,使用字典对象的 keys() 方法可以返回字典的“键”列表,使用字典对象的 values() 方法可以返回字典的“值”列表。2.13 假设有列表a = name, age, sex与b = Dong, 38, Male,请使用一个语句将这两个列表的内容转换为字典,并且以列表a中的元素为“键”,以列表b中的元素为“值”,这个语句可以写为 c = dict(zip(a,b)
14、 。2.14 假设有一个列表a,现要求从列表a中每3个元素取1个,并且将取到的元素组成新的列表b,可以使用语句 b = a:3 。2.15 使用列表推导式生成包含10个数字5的列表,语句可以写为 5 for i in range(10) 。2.16 不可以 (可以、不可以)使用del命令来删除元组中的部分元素。第3章 选择及循环3.1 分析逻辑运算符“or”的短路求值特性。答:假设有表达式“表达式1 or 表达式2”,如果表达式1的值等价于True,那么无论表达式2的值是什么,整个表达式的值总是等价于True。因此,不需要再计算表达式2的值。3.2 编写程序,运行后用户输入4位整数作为年份,判
15、断其是否为闰年。如果年份能被400整除,则为闰年;如果年份能被4整除但不能被100整除也为闰年。答:1)Python 代码x = input(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 代码x = input(Please input an integer of 4 digits meaning the year:)if x%400=0 or (x%4=0 and
16、not x%100=0): print Yeselse: print No3.3 Python提供了两种基本的循环结构: for循环 与 while循环 。3.4 编写程序,生成一个包含50个随机整数的列表,然后删除其中所有奇数。(提示:从后向前删。)答:Python 代码如下,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)3.5 编写程序,生成一个包含20个随机整数的列表,然后对其中偶数下标的元素进行降序
17、排列,奇数下标的元素不变。(提示:使用切片。)答:Python 代码如下,import randomx = random.randint(0,100) for i in range(20)print(x)y = x:2y.sort(reverse=True)x:2 = yprint(x)3.6 编写程序,用户从键盘输入小于1000的整数,对其进行因式分解。例如,10=25,60=2235。答:1)Python 代码x = input(Please input an integer less than 1000:)x = eval(x)t = xi = 2result = while True:
18、 if t=1: break if t%i=0: result.append(i) t = t/i else: i+=1print(x,=,*.join(map(str,result)2)Python 代码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.7 编写程序,至少使用2种不同的方法计算100
19、以内所有奇数的与。答:Python 代码如下,如果使用只需要把其中的print()函数改为print语句即可。x = i for i in range(1,100) if i%2=1print(sum(x)print(sum(range(1,100):2)3.8 编写程序,输出所有由1、2、3、4这四个数字组成的素数,并且在每个素数中每个数字只使用一次。答:Python 代码如下,答:Python 代码如下,如果使用Python 2.7.8只需要把其中的print()函数改为print语句即可。x = input(Please input x:)x = eval(x)if x=20: prin
20、t(0)elif 0=x5: print(x)elif 5=x10: print(3*x-5)elif 10=x20: print(0.5*x-2)3.9 编写程序,实现分段函数计算,如下表所示。xyx000=x5x5=x103x-510=x2020=x0答:Python 代码如下,如果使用Python 2.7.8只需要把其中的print()函数改为print语句即可。x = input(Please input x:)x = eval(x)if x=20: print(0)elif 0=x5: print(x)elif 5=x10: print(3*x-5)elif 10=x20:print
21、(0.5*x-2)第4章 字符串及正则表达式4.1 假设有一段英文,其中有单独的字母“I”误写为“i”,请编写程序进行纠正。答:这里给出Python 代码,如果使用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.replace(i ,I )x = x.replace( i , I )print(x)2)使用正则表达式x = i am a teacher,i am man, and
22、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:result.start(0)+I+xresult.end(0)-1: else: breakprint(x)4.2 假设有一段英文,其中有单词中间的字母“i”误写为“I”,请编写
23、程序进行纠正。答:这里给出Python 代码,如果使用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 = pattern.search(x) if result: if result.start(0) != 0: x = x:result.start(0)+1+i+xresult.end(
24、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 代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。1)方法一import rex = This is a a desk.pattern = pile(rb(w+)(s+1)1,b)matchRe
25、sult = 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),matchResult.group(1)4.4 简单解释Python的字符串驻留机制。答:Python支持字符串驻留机制,即:对于短字符串,将其赋值给多个不同的对象时,内存中只有一个副本,多个对象共享该副本。这一
26、点不适用于长字符串,即长字符串不遵守驻留机制,下面的代码演示了短字符串与长字符串在这方面的区别。 a = 1234 b = 1234 id(a) = id(b)True a = 1234*50 b = 1234*50 id(a) = id(b)False4.5 编写程序,用户输入一段英文,然后输出这段英文中所有长度为3个字母的单词。答:这里给出Python 代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。import rex = input(Please input a string:)pattern = pile(rba-zA-Z3b)pri
27、nt(pattern.findall(x)第5章 函数设计及使用5.1 运行小节最后的示例代码,查看结果并分析原因。答:原因是对于函数的默认值参数只会被处理一次,下次再调用函数并且不为默认值参数赋值时会继续使用上一次的结果,对于列表这样的结构,如果调用函数时为默认值参数的列表插入或删除了元素,将会得到保留,从而影响下一次调用。5.2 编写函数,判断一个整数是否为素数,并编写主程序调用该函数。答:这里给出Python 代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。import mathdef IsPrime(v): n = int(math.s
28、qrt(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 代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。def demo(v): capital = little = digit = other =0 for i in v: if A
29、=i=Z: capital+=1 elif a=i=z: little+=1 elif 0=i def demo():a=3print a a=5 demo()3 a55.8 lambda表达式只能用来创建匿名函数,不能为这样的函数起名字。(对、错)5.9 编写函数,可以接收任意多个整数并输出其中的最大值与所有整数之与。答:这里给出Python 代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。def demo(*v): print(v) print(max(v) print(sum(v)demo(1,2,3)demo(1,2,3,4)demo(
30、1,2,3,4,5)5.10 编写函数,模拟内置函数sum()。答:这里给出Python 代码,如果使用的话只需要修改其中的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.11 包含 yield 语句的函数可以用来创建生成器。5.12 编写函数,模拟内置函数sorted()。答:这里给出Python 代码,如果使用Python 2.7.8的话只需要修改其中的print()函数为print语句即可。def S
31、orted(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 代码为import typesclass Person(object): #基类必须继承于object,否则在派生类中将无法使用super()函数 def _init_(self, name = ,
32、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(age,int): print(age must be integer.) return self._age = age def setSex(self,
33、 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 = man, major = Computer): #调用基类构造方法初始化基类的私有数据成员 super(Student, self)._init_(na
34、me, 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._major)if _name_ =_main_: zhangsan = Person(Zhang San, 19, man) zhangsan.show() l
35、isi = Student(Li Si,32, man, Math) lisi.show()6.2 设计一个三维向量类,并实现向量的加法、减法以及向量及标量的乘法与除法运算。答:Python 代码如下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() return r def _sub_(self, n): r = Vecter3() return r def _mul_(self, n): r = Vecter3()
36、 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 = 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
37、)v1 = Vecter3(1,2,3)v2 = Vecter3(4,5,6)v3 = v1+v2v3.show()v4 = v1-v2v4.show()v5 = v1*3v5.show()v6 = v1/2v6.show()6.3 面向对象程序设计的三要素分别为 封装 、 继承 与 多态 。6.4 简单解释Python中以下划线开头的变量名特点。答:在Python中,以下划线开头的变量名有特殊的含义,尤其是在类的定义中。用下划线作为变量前缀与后缀来表示类的特殊成员:l _xxx:这样的对象叫做保护变量,不能用from module import *导入,只有类对象与子类对象能访问这些变量;l
38、 _xxx_:系统定义的特殊成员名字;l _xxx:类中的私有成员,只有类对象自己能访问,子类对象也不能访问到这个成员,但在对象外部可以通过“”这样的特殊方式来访问。Python中没有纯粹的C+意义上的私有成员。6.5 及运算符“*”对应的特殊方法名为 _pow_() ,及运算符“/”对应的特殊方法名为 _floordiv_() 。6.6 假设a为类A的对象且包含一个私有数据成员“_value”,那么在类的外部通过对象a直接将其私有数据成员“_value”的值设置为3的语句可以写作 a._A_value 。第7章 文件操作7.1 假设有一个英文文本文件,编写程序读取其内容,并将其中的大写字母变
39、为小写字母,小写字母变为大写字母。答:f = open(rd:1.txt,r)s = f.readlines()f.close()r = i.s() for i in sf = open(rd:2.txt,w)f.writelines(r)f.close()7.2 编写程序,将包含学生成绩的字典保存为二进制文件,然后再读取内容并显示。答:Python 代码import pickled = 张三:98,李四:90,王五:100print(d)f = open(score.dat,wb)pickle.dump(1,f)pickle.dump(d,f)f = 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)文本文件文本文件存储的是常规字符串,由若干文本行组成,通常每行以换行符n结尾。常规字符串是指记事本或其他文本编辑器能正常显示、编辑并且人类能够直接阅读与理解的字符串,如英文字母、汉字、数
限制150内