《Python程序设计》习题与答案Word下载.docx
《《Python程序设计》习题与答案Word下载.docx》由会员分享,可在线阅读,更多相关《《Python程序设计》习题与答案Word下载.docx(38页珍藏版)》请在冰豆网上搜索。
exceptBaseException:
print('
Youmustinputaninteger.'
importtypes
iftype(x)!
=types.IntType:
print'
eliflen(str(x))!
=4:
printx//100
第2章Python数据结构
2.1为什么应尽量从列表的尾部进行元素的增加与删除操作?
当列表增加或删除元素时,列表对象自动进行内存扩展或收缩,从而保证元素之间没有缝隙,但这涉及到
列表元素的移动,效率较低,应尽量从列表尾部进行元素的增加与删除操作以提高处理速度。
2.2编写程序,生成包含1000个0到100之间的随机整数,并统计每个元素的岀现次数。
使用集
合。
importrandom
x=[random.randint(0,100)foriinrange(1000)]
d=set(x)
forvind:
print(v,'
:
x.count(v))
printv,'
x.count(v)
2.3编写程序,用户输入一个列表和2个整数作为下标,然后输岀列表中介于2个下标之间的元素组成的
子列表。
例如用户输入[1,2,3,4,5,6]和2,5,程序输岀[3,4,5,6]。
Pleaseinputalist:
x=eval(x)
start,end=eval(input('
Pleaseinputthestartpositionandtheendposition:
))
print(x[start:
end])
start,end=input('
Pleaseinputthestartpositionandtheendposition:
printx[start:
end]
2.4设计一个字典,并编写程序,用户输入内容作为键,然后输岀字典中对应的值,如果用户输入的键不存在,则输岀“您输入的键不存在!
”
d={1:
a'
2:
b'
3:
c'
4:
d'
}
v=input('
Pleaseinputakey:
v=eval(v)
print(d.get(v,'
您输入的的键不存在’))
2.5编写程序,生成包含20个随机数的列表,然后将前10个元素升序排列,后10个元素降序排列,并输
岀结果。
x=[random.randint(0,100)foriinrange(20)]
y=x[0:
10]
y.sort()x[0:
10]=yy=x[10:
20]y.sort(reverse=True)x[10:
20]=yprint(x)
printx
y.sort()
x[0:
10]=y
y=x[10:
20]
y.sort(reverse=True)
x[10:
20]=y
2.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使用列表推导式生成包含10个数字5的列表,语句可以写为[5foriinrange(10)]。
2.10不可以(可以、不可以)使用del命令来删除元组中的部分元素。
第3章选择结构与循环结构
3.1分析逻辑运算符“or”的短路求值特性。
假设有表达式“表达式1or表达式2”,如果表达式1的值等价于True,那么无论表达式2的值是什么,
整个表达式的值总是等价于True。
因此,不需要再计算表达式2的值。
3.2编写程序,运行后用户输入4位整数作为年份,判断其是否为闰年。
如果年份能被400整除,则为闰
年;
如果年份能被4整除但不能被100整除也为闰年。
x=input(卩leaseinputanintegerof4digitsmeaningtheyear:
ifx%400==0or(x%4==0andnotx%100==0):
Yes'
No'
Pleaseinputanintegerof4digitsmeaningtheyear:
3.3编写程序,生成一个包含50个随机整数的列表,然后删除其中所有奇数。
从后向前删。
x=[random.randint(0,100)foriinrange(50)]
i=len(x)-1
whilei>
=0:
ifx[i]%2==1:
delx[i]
i-=1
把上面的代码中第三行和最后一行改为printx即可。
34编写程序,生成一个包含20个随机整数的列表,然后对其中偶数下标的元素进行降序排列,奇数下标
的元素不变。
使用切片。
y=x[:
2]
x[:
2]=y
35编写程序,用户从键盘输入小于1000的整数,对其进行因式分解。
例如,10=2X5,60=2X2X3X5
Pleaseinputanintegerlessthan1000:
x=eval('
x'
t=x
i=2
result=[]
whileTrue:
ift==1:
break
ift%i==0:
result.append(i)
t=t/i
i+=1
Printx,'
='
*'
.join(map(str,result))
printx,'
3.6编写程序,至少使用2种不同的方法计算100以内所有奇数的和
x=[iforiinrange(1,100)ifi%2==1]
print(sum(x))
print(sum(range(1,100)[:
2]))
3.7编写程序,实现分段函数计算,如下表所示。
x
y
x<
0<
=x<
5
5<
10
3x-5
10<
20
0.5x-2
20<
=x
Pleaseinputx:
ifx<
0orx>
=20:
print(0)
elif0<
5:
print(x)
elif5<
10:
print(3*x-5)
elif10<
20:
print(0.5*x-2)
第4章字符串与正则表达式
4.1假设有一段英文,其中有单独的字母"
I"
误写为“i"
请编写程序进行纠正。
1)不使用正则表达式
x="
iamateacher」amman,andiam38yearsold.Iamnotabusinessman."
x=x.replace('
i'
I'
i'
I'
2)使用正则表达式
iamateacher,iamman,andiam38yearsold.Iamnotabusinessman."
importre
pattern=pile(r'
(?
:
F\w]|\b)i(?
F\w])'
result=pattern.search(x)
ifresult:
ifresult.start(O)!
=0:
x=x[:
result.start(0)+1]+T+x[result.end(0)-1:
]
result.start(O)]+T+x[result.end(0)-1:
4.2假设有一段英文,其中有单词中间的字母“i”误写为“I”,请编写程序进行纠正。
Iamateacher,Iamman,andIam38yearsold.IamnotabusInessman."
[\w])I(?
[\w])'
result.start(0)+1]+'
i'
+x[result.end(0)-1:
result.start(0)]+'
4.3有一段英文文本,其中有单词连续重复了2次,编写程序检查重复的单词并只保留一个。
例如文本内
容为“Thisisisadesk."
,程序输岀为“Thisisadesk.”
1)方法importre
x='
Thisisaadesk.'
pattern=pile(r'
\b(\w+)(\s+\1){1,}\b'
)matchResult=pattern.search(x)
x=pattern.sub(matchResult.group
(1),x)print(x)
2)方法二
P<
f>
\b\w+\b)\s(?
P=f)'
x=x.replace(matchResult.group(0),matchResult.group
(1))
4.4简单解释Python的字符串驻留机制。
Python支持字符串驻留机制,即:
对于短字符串,将其赋值给多个不同的对象时,内存中只有一个副本,多个对象共享该副本。
这一点不适用于长字符串,即长字符串不遵守驻留机制,下面的代码演示了短字符串和长字符串在这方面的区别。
a='
1234'
b='
id(a)==id(b)
True
*50
*50>
id(a)==id(b)False
4.5编写程序,用户输入一段英文,然后输岀这段英文中所有长度为3个字母的单词。
Pleaseinputastring:
)pattern=pile(r'
\b[a-zA-Z]{3}\b'
)print(pattern.findall(x))
第5章函数设计与使用
原因是对于函数的默认值参数只会被处理一次,下次再调用函数并且不为默认值参数赋值时会继续使用上一次的结果,对于列表这样的结构,如果调用函数时为默认值参数的列表插入或删除了元素,将会得到保留,从而影响下一次调用。
5.2编写函数,判断一个整数是否为素数,并编写主程序调用该函数。
importmath
defIsPrime(v):
n=int(math.sqrt(v)+1)
foriinrange(2,n):
ifv%i==0:
return'
print(lsPrime(37))
print(lsPrime(60))
print(lsPrime(113))
5.3编写函数,接收一个字符串,分别统计大写字母、小写字母、数字、其他字符的个数,并以元组的形式返回结果。
defdemo(v):
capital=little=digit=other=0
foriinv:
if'
A'
v=i<
Z'
capital+=1
elif'
z'
little+=1
0'
<
=i<
9'
digit+=1
other+=1
return(capital,little,digit,other)
capital=little=digit=other=0'
print(demo(x))
5.4在Python程序中,局部变量会隐藏同名的全局变量吗?
请编写代码进行验证。
答案:
会。
defdemo():
a=3
printa>
a=5
demo()
3
a
5.5编写函数,可以接收任意多个整数并输岀其中的最大值和所有整数之和
defdemo(*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()。
defSum(v):
s=0
s+=i
returns
x=[1,2,3,4,5]
print(Sum(x))
x=(123,4,5)
5.7编写函数,模拟内置函数sorted()。
defSorted(v):
t=v[:
r=[]
whilet:
tt=min(t)
r.append(tt)
t.remove(tt)
returnr
x=[1,3,5,2,1,0,9,7]
print(Sorted(x))
第6章面向对象程序设计
6.1继承6.5节例2中的Person类生成Student类,填写新的函数用来设置学生专业,然后生成该类对象并显示信息。
classPerson(object):
#基类必须继承于object,否则在派生类中将无法使用super()函数
def__init__(self,name='
age=20,sex='
man'
):
self.setName(name)
self.setAge(age)
self.setSex(sex)
defsetName(self,name):
ifnotisinstance(name,str):
namemustbestring.'
return
self.__name=name
defsetAge(self,age):
ifnotisinstance(age,int):
agemustbeinteger.'
self.__age=age
defsetSex(self,sex):
ifsex!
='
andsex!
woman'
sexmustbe"
man"
or"
woman"
self.__sex=sex
defshow(self):
print(self.__name)
print(self.__age)
print(self.__sex)
classStudent(Person):
def__init__(self,name='
age=30,sex='
major='
Computer'
#调用基类构造方法初始化基类的私有数据成员
super(Student,self).__init__(name,age,sex)
self.setMajor(major)#初始化派生类的数据成员
defsetMajor(self,major):
ifnotisinstance(major,str):
majormustbeastring.'
self.__major=major
super(Student,self).show()
print(self.__major)
if__name__=='
__main__'
zhangsan=Person('
ZhangSan'
19,'
zhangsan.show()
lisi=Student('
LiSi'
32,'
,‘Math'
lisi.show()
6.2设计一个三维向量类,并实现向量的加法、减法以及向量与标量的乘法和除法运算。
classVecter3:
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=self.X+n.X
r.Y=self.Y+n.Y
r.Z=self.Z+n.Z
def__sub__(self,n):
r.X=self.X-n.X
r.Y=self.Y-n.Y
r.Z=self.Z-n.Z
def__mul__(self,n):
r.X=self.X*n
r.Y=self.Y*n
r.Z=self.Z*n
def__truediv__(self,n):
r.X=self.X/n
r.Y=self.Y/n
r.Z=self.Z/n