《Python程序设计基础》习题答案与分析Word格式.doc
《《Python程序设计基础》习题答案与分析Word格式.doc》由会员分享,可在线阅读,更多相关《《Python程序设计基础》习题答案与分析Word格式.doc(27页珍藏版)》请在冰点文库上搜索。
1.5pip是目前比较常用的Python扩展库管理工具。
1.6解释Python脚本程序的“__name__”变量及其作用。
每个Python脚本在运行时都有一个“__name__”属性。
如果脚本作为模块被导入,则其“__name__”属性的值被自动设置为模块名;
如果脚本独立运行,则其“__name__”属性值被自动设置为“__main__”。
利用“__name__”属性即可控制Python程序的运行方式。
1.7运算符“%”可以(可以、不可以)对浮点数进行求余数操作。
1.8一个数字“5”是(是、不是)合法的Python表达式。
1.9在Python2.x中,input()函数接收到的数据类型由界定符确定,而在Python3.x中该函数则认为接收到的用户输入数据一律为字符串。
1.10编写程序,用户输入一个三位以上的整数,输出其百位以上的数字。
例如用户输入1234,则程序输出12。
(提示:
使用整除运算。
)
1)Python3.4.2代码:
x=input('
Pleaseinputanintegerofmorethan3digits:
'
try:
x=int(x)
x=x//100
ifx==0:
print('
Youmustinputanintegerofmorethan3digits.'
else:
print(x)
exceptBaseException:
print('
Youmustinputaninteger.'
2)Python2.7.8代码:
importtypes
iftype(x)!
=types.IntType:
print'
eliflen(str(x))!
=4:
else:
printx//100
第2章Python序列
2.1为什么应尽量从列表的尾部进行元素的增加与删除操作?
当列表增加或删除元素时,列表对象自动进行内存扩展或收缩,从而保证元素之间没有缝隙,但这涉及到列表元素的移动,效率较低,应尽量从列表尾部进行元素的增加与删除操作以提高处理速度。
2.2range()函数在Python2.x中返回一个包含整数的列表,而Python3.x的range()函数返回一个可迭代的range对象。
2.3编写程序,生成包含1000个0到100之间的随机整数,并统计每个元素的出现次数。
可以使用集合来实现该功能。
1)Python3.4.2代码
importrandom
x=[random.randint(0,100)foriinrange(1000)]
d=set(x)
forvind:
print(v,'
:
x.count(v))
2)Python2.7.8代码
printv,'
x.count(v)
也可以直接使用字典来实现该功能,并且获得更高的执行效率,例如下面的Python3.4.2代码:
listRandom=[random.randint(1,100)foriinrange(1000000)]
d=dict()
start=time.time()
foriinlistRandom:
#对随机数列表扫描一次,即可得到结果
d[i]=d.get(i,0)+1
print(time.time()-start)
2.4表达式“[3]in[1,2,3,4]”的值为False。
2.5编写程序,用户输入一个列表和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('
printx[start:
end]
2.6列表对象的sort()方法用来对列表元素进行原地排序,该函数返回值为None。
2.7列表对象的remove()方法删除首次出现的指定元素,如果列表中不存在要删除的元素,则抛出异常。
2.8假设列表对象aList的值为[3,4,5,6,7,9,11,13,15,17],那么切片aList[3:
7]得到的值是[6,7,9,11]。
2.9设计一个字典,并编写程序,用户输入内容作为“键”,然后输出字典中对应的“值”,如果用户输入的“键”不存在,则输出“您输入的键不存在!
”
d={1:
a'
2:
b'
3:
c'
4:
d'
}
v=input('
Pleaseinputakey:
v=eval(v)
print(d.get(v,'
您输入的的键不存在'
2.10编写程序,生成包含20个随机数的列表,然后将前10个元素升序排列,后10个元素降序排列,并输出结果。
x=[random.randint(0,100)foriinrange(20)]
print(x)
y=x[0:
10]
y.sort()
x[0:
10]=y
y=x[10:
20]
y.sort(reverse=True)
x[10:
20]=y
printx
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))。
2.14假设有一个列表a,现要求从列表a中每3个元素取1个,并且将取到的元素组成新的列表b,可以使用语句b=a[:
3]。
2.15使用列表推导式生成包含10个数字5的列表,语句可以写为[5foriinrange(10)]。
2.16不可以(可以、不可以)使用del命令来删除元组中的部分元素。
第3章选择与循环
3.1分析逻辑运算符“or”的短路求值特性。
假设有表达式“表达式1or表达式2”,如果表达式1的值等价于True,那么无论表达式2的值是什么,整个表达式的值总是等价于True。
因此,不需要再计算表达式2的值。
3.2编写程序,运行后用户输入4位整数作为年份,判断其是否为闰年。
如果年份能被400整除,则为闰年;
如果年份能被4整除但不能被100整除也为闰年。
Pleaseinputanintegerof4digitsmeaningtheyear:
ifx%400==0or(x%4==0andnotx%100==0):
Yes'
No'
3.3Python提供了两种基本的循环结构:
for循环和while循环。
3.4编写程序,生成一个包含50个随机整数的列表,然后删除其中所有奇数。
从后向前删。
Python3.4.2代码如下,
x=[random.randint(0,100)foriinrange(50)]
i=len(x)-1
whilei>
=0:
ifx[i]%2==1:
delx[i]
i-=1
3.5编写程序,生成一个包含20个随机整数的列表,然后对其中偶数下标的元素进行降序排列,奇数下标的元素不变。
使用切片。
y=x[:
2]
x[:
2]=y
3.6编写程序,用户从键盘输入小于1000的整数,对其进行因式分解。
例如,10=2×
5,60=2×
2×
3×
5。
Pleaseinputanintegerlessthan1000:
t=x
i=2
result=[]
whileTrue:
ift==1:
break
ift%i==0:
result.append(i)
t=t/i
i+=1
print(x,'
='
'
*'
.join(map(str,result)))
printx,'
.join(map(str,result))
3.7编写程序,至少使用2种不同的方法计算100以内所有奇数的和。
Python3.4.2代码如下,如果使用Python2.7.8只需要把其中的print()函数改为print语句即可。
x=[iforiinrange(1,100)ifi%2==1]
print(sum(x))
print(sum(range(1,100)[:
2]))
3.8编写程序,输出所有由1、2、3、4这四个数字组成的素数,并且在每个素数中每个数字只使用一次。
Pleaseinputx:
ifx<
0orx>
=20:
print(0)
elif0<
=x<
5:
print(x)
elif5<
10:
print(3*x-5)
elif10<
20:
print(0.5*x-2)
3.9编写程序,实现分段函数计算,如下表所示。
x
y
x<
0<
5
5<
10
3x-5
10<
20
0.5x-2
20<
=x
print(0.5*x-2)第4章字符串与正则表达式
4.1假设有一段英文,其中有单独的字母“I”误写为“i”,请编写程序进行纠正。
这里给出Python3.4.2代码,如果使用Python2.7.8的话只需要修改其中的print()函数为print语句即可。
1)不使用正则表达式
x="
iamateacher,iamman,andiam38yearsold.Iamnotabusinessman."
x=x.replace('
i'
I'
i'
I'
2)使用正则表达式
importre
pattern=pile(r'
(?
[^\w]|\b)i(?
[^\w])'
result=pattern.search(x)
ifresult:
ifresult.start(0)!
=0:
x=x[:
result.start(0)+1]+'
I'
+x[result.end(0)-1:
]
else:
result.start(0)]+'
4.2假设有一段英文,其中有单词中间的字母“i”误写为“I”,请编写程序进行纠正。
Iamateacher,Iamman,andIam38yearsold.IamnotabusInessman."
[\w])I(?
[\w])'
i'
4.3有一段英文文本,其中有单词连续重复了2次,编写程序检查重复的单词并只保留一个。
例如文本内容为“Thisisisadesk.”,程序输出为“Thisisadesk.”
1)方法一
x='
Thisisaadesk.'
\b(\w+)(\s+\1){1,}\b'
matchResult=pattern.search(x)
x=pattern.sub(matchResult.group
(1),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)
*50
False
4.5编写程序,用户输入一段英文,然后输出这段英文中所有长度为3个字母的单词。
Pleaseinputastring:
\b[a-zA-Z]{3}\b'
print(pattern.findall(x))
第5章函数设计与使用
5.1运行5.3.1小节最后的示例代码,查看结果并分析原因。
原因是对于函数的默认值参数只会被处理一次,下次再调用函数并且不为默认值参数赋值时会继续使用上一次的结果,对于列表这样的结构,如果调用函数时为默认值参数的列表插入或删除了元素,将会得到保留,从而影响下一次调用。
5.2编写函数,判断一个整数是否为素数,并编写主程序调用该函数。
importmath
defIsPrime(v):
n=int(math.sqrt(v)+1)
foriinrange(2,n):
ifv%i==0:
return'
return'
print(IsPrime(37))
print(IsPrime(60))
print(Is