python语言程序设计基础课后习题答案
2019-06-21 18:36
1691 查看
第二章
1获得用户输入的一个整数N,计算并输出N的32次方
常见错误:
n = input() print(n**32)
2 --------------------------------------------------------------------------- TypeError Traceback (most recent call last) <ipython-input-2-92804f3e9c14> in <module>() 1 n = input() ----> 2 print(n**32) TypeError: unsupported operand type(s) for ** or pow(): 'str' and 'int'
正确实例:
n = eval(input())#具体可参考eval()的使用 print(n**32)
2 4294967296
2.获得用户输入的一段文字,将这段文字进行垂直输出:
L = input() for i in L: print(i)
hello world! h e l l o w o r l d !
3.获得用户输入的一个合法的算式,例如:3+4,并输出运算结果
print(eval(input()))
3+2 5
获得用户输入的一个小数,并输出其整数部分
num = eval(input()) print(round(num))#round()函数用法另行查找
10.24 10
第三章
1.获得用户输入的一个整数,并输出百位及以上数字
num = eval(input()) num = num / 100 print(round(num)) #下为另一方法,实现方法很多 #num = input() #print(num[:-2])
1024 10
2.获得用户输入的一个字符串,将字符串按照空格分割,然后逐行打印出来
L = input() s = "" for i in L: if i == ' ' or i == L[-1]: if i == L[-1]: s += L[-1] print(s) s = "" else: s += i #学习下一章,将会有一个str.split(),更方便,可以提前了解
hello world! hello world!
3.程序读入一个表示星期几的数字(1—7),输出对应的星期字符名称,例如2,返回星期二
num_to_days = ["星期一", "星期二", "星期三", "星期四", "星期五", "星期六", "星期七",] num = eval(input()) print(num_to_days[num-1])
3 星期三
4.输入五位数字,判断是否为回文数字
num = input()#可以当作字符串处理,也可以用类似判断水仙花的方法,代码会更少 for i in range(int(len(num)/2)): if num[i] != num[-(i+1)]: print("no") break else:#奖励机制,下一章会讲到 print("yes")
hello no
5.输入一个十进制数,分别输出其二进制,八进制,十六进制字符串
num = eval(input()) print("{}的二进制数为:{:b},八进制数为:{:o},十六进制数为:{:x}".format(num,num,num,num))
425 425的二进制数为:110101001,八进制数为:651,十六进制数为:1a9
第四章
1.输入一个年份,判断是否为闰年,闰年条件:能被4整除但不能被100整除或者能被400整除
year = eval(input()) if (year % 4 == 0 and year % 100) or year % 400 == 0: print("yes") else: print("no")
2000 yes
2.获得两个数的最大公约数和最小公倍数,用辗转相除法
a = eval(input()) b = eval(input()) num1 = a num2 = b if b > a: (a,b) = (b,a)#交换a,b while a%b: c = a % b a = b b = c print("{}和{}的最大公约数是:{},最小公倍数为:{}".format(num1,num2,b,num1*num2/b))
8 4 8和4的最大公约数是:4,最小公倍数为:8.0
3.统计不同字符个数。用户输入一行字符,请统计数字,字母,空格,其他字符个数。
string = input() dig = 0 alp = 0 space = 0 other = 0 for i in string: if i.upper() >= 'A' and i.upper() <= 'Z': alp += 1 elif i >= '0' and i <= '9': dig += 1 elif i == ' ': space += 1 else: other += 1 print("{}中数字个数:{},字母个数:{},空格个数:{},其他:{}".format(string,dig,alp,space,other))
123,hello world! 123,hello world!中数字个数:3,字母个数:10,空格个数:1,其他:2
4.猜数字续。
import random target = random.randint(1,1000) count = 0 while True: try: guess = eval(input('请输入猜测的整数(1-1000):')) count += 1 if guess > target: print("猜大了!") elif guess < target: print("猜小了!") else: print("猜对了!") break except: print("输入有误!请重新输入一个整数!") print("此轮猜测次数为:",count)
请输入猜测的整数(1-1000):i 输入有误!请重新输入一个整数! 请输入猜测的整数(1-1000):100 猜小了! 请输入猜测的整数(1-1000):300 猜小了! 请输入猜测的整数(1-1000):800 猜小了! 请输入猜测的整数(1-1000):900 猜小了! 请输入猜测的整数(1-1000):950 猜大了! 请输入猜测的整数(1-1000):925 猜大了! 请输入猜测的整数(1-1000):910 猜大了! 请输入猜测的整数(1-1000):905 猜对了! 此轮猜测次数为: 9
5.羊车门问题
import random x=100000 change=0 nochange=0 for i in range(1,x+1): guess=random.randrange(1,4) real=random.randrange(1,4) if guess==real: nochange=nochange+1 else: change=change+1 print("不更改选择得到汽车的概率为{}".format(nochange/x)) print("更改选择得到汽车的概率为{}".format(change/x))
不更改选择得到汽车的概率为0.33338 更改选择得到汽车的概率为0.66662
第五章
1.实现isnum()函数,参数为一个字符串,如果字符串属于整数,浮点数,或者复数的表示,则返回True,否则False
def isnum(string): try: if isinstance(eval(string),int) or isinstance(eval(string),float) or isinstance(eval(string),complex): print("True") except: print("False") string = input('请输入一个字符串:') isnum(string)
请输入一个字符串:1+1j True
2.实现isprime(),参数为整数,要有有异常处理,返回True或者False
def isprime(num): for i in range(2,num): if num % i == 0: return False return True try: num = eval(input('请输入一个整数:')) print(isprime(num)) except: print('请输入一个整数!')
请输入一个整数:17 True
3.编写一个函数,统计传入字符串中数字,字母,空格及其他字符个数
参考上一课第三题,写进函数。
4.编写函数,打印200以内的素数,以空格分隔
def printf(): for num in range(1,201): for i in range(2,num): if num % i == 0: break else: print(num,end = ' ') printf()
1 2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103 107 109 113 127 131 137 139 149 151 157 163 167 173 179 181 191 193 197 199
5.利用递归求第n个斐波那契数
def Fibonacci(n): if n <= 2: return 1 else: return Fibonacci(n-1)+Fibonacci(n-2) n = eval(input('请输入一个整数:')) print(Fibonacci(n))
请输入一个整数:6 8
第六章
1.英文字符频率统计。编写一个程序,对给定字符串中出现的a~z字母频率进行分析,忽略大小写,采用降序方式输出。
txt = "i love three things,the sun for morning,the moon for night,and you for ever." txt = txt.lower() counts = dict() for i in txt: counts[i] = counts.get(i,0) + 1 items = list(counts.items())#键值对以元组形式返回 items.sort(key = lambda x:x[1], reverse = True)#以元组中第二个值,即原始dict中的值为排列依据 for i in items: a, b = i print('{}出现的次数为{}'.format(a,b))
出现的次数为12 o出现的次数为8 e出现的次数为7 n出现的次数为7 r出现的次数为6 t出现的次数为5 h出现的次数为5 i出现的次数为4 g出现的次数为3 ,出现的次数为3 f出现的次数为3 v出现的次数为2 s出现的次数为2 u出现的次数为2 m出现的次数为2 l出现的次数为1 a出现的次数为1 d出现的次数为1 y出现的次数为1 .出现的次数为1
2.中文字符频率统计。类比上例。
3.随机密码生成。编写程序在26个字母大小写,和九个数字组成的列表中随机生成10个八位密码。
import random mimalist = [chr(i) for i in range(97,123)] + [chr(i) for i in range(65,91)] + [chr(i) for i in range(49,58)] print(mimalist) #以上为列表推导式,其实可以理解成把for 循环压扁。具体用法百度。 mima = [[mimalist[random.randint(0,60)] for i in range(8)] for j in range(10)] for i in mima: print(''.join(i))#列表转字符串输出
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '1', '2', '3', '4', '5', '6', '7', '8', '9'] CrOEta1h a8YfBfiL Lrz9Hpfv CaJZvbaX KiDgfTO2 wCOA2mS9 c795COYs b3OdOdeY 6f22JdIG Gn3vqHoA
4.重复元素判定。接受列表作为参数,如果一个元素出现次数不止一次,则返回True,但是不改变原列表值。
#可以重头到尾找,我这里用序列类型的count操作 def find_repeat(L): for i in L: if L.count(i) > 1: return True return False L = input("请输入一个列表") L = list(L) print(L) print(find_repeat(L)) print(L)
请输入一个列表ilovepython ['i', 'l', 'o', 'v', 'e', 'p', 'y', 't', 'h', 'o', 'n'] True ['i', 'l', 'o', 'v', 'e', 'p', 'y', 't', 'h', 'o', 'n']
5.重复元素判定。利用集合无重复性。
def find_repeat(L): new_L = set(L) #集合类型会自动去重 if L != new_L: return True return False L = input("请输入一个列表") L = list(L) print(L) print(find_repeat(L)) print(L)
请输入一个列表ilovepython ['i', 'l', 'o', 'v', 'e', 'p', 'y', 't', 'h', 'o', 'n'] True ['i', 'l', 'o', 'v', 'e', 'p', 'y', 't', 'h', 'o', 'n']
第七章
1.输入一个文件和一个字符,统计该字符在文件中出现的次数。
def Count(fname, S, count): file = fname + '.txt' f = open(file, 'r', encoding='utf-8') txt = f.read() f.close() print(txt) count = txt.count(S) print('“{}”字符在《{}》中出现的的次数是:{}次'.format(S, fname, count)) fname = input('请输入txt文件名称:') S = input('请输入一个字符:') count = 0 Count(fname, S, count)
请输入txt文件名称:my 请输入一个字符:the i love three things. The sun,the moon,the night. “the”字符在《my》中出现的的次数是:2次
2.假设有一个英文文本文件,编写一个程序读取其内容并将里面的大写字母变成小写字母,小写字母变成大写字母。
def transfer(fname): file = fname + '.txt' f = open(file, 'r', encoding='utf-8') txt = f.readlines() f.close() new_txt = [] print(txt) for lines in txt: for i in lines: if i >= 'A' and i <= 'Z': new_txt.append(i.lower()) elif i >= 'a' and i <= 'z': new_txt.append(i.upper()) else: new_txt.append(i) f = open(file, 'w', encoding='utf-8') for lines in new_txt: f.writelines(lines) f.close() fname = input('请输入txt文件名称:') transfer(fname)
请输入txt文件名称:my ['i LOVE THREE THINGS.\n', 'tHE SUN,THE MOON,AND YOU.']
okk,结课。还有面向对象部分,有必要了解,慢慢来,加油!
还有两道题目推荐文章:https://juejin.im/post/5c07ddcd6fb9a049d7477ab3#heading-4
相关文章推荐
- Python语言程序设计基础(第二版)嵩天等课后习题答案
- 【鱼C·零基础入门学习Python】课后习题答案 第14课
- Python语言程序设计基础(第2版) 课后题 第六章
- java语言程序设计基础课后习题第二章
- Python语言程序设计基础(第2版) 课后题 第五章
- Python语言程序设计基础(第2版) 课后题 第四章
- JAVA语言程序设计基础课后习题第三章
- 新版汇编语言程序设计【课后习题答案】
- JAVA语言程序设计基础课后习题第四章
- JAVA语言程序设计基础课后习题第五章
- JAVA语言程序设计基础课后习题第六章
- Python语言程序设计基础(第2版) 课后题 第一章
- 中国大学 MOOC 课程 《Python 语言程序设计》第六周课后习题
- 中国大学 MOOC 课程 《Python 语言程序设计》第五周课后习题
- Python语言程序设计基础(第2版) 课后题 第二章
- Python语言程序设计基础(第2版) 课后题 第七章
- 算法导论第三版第15章课后答案15.4-2(python语言编写)
- C语言程序设计谭浩强版课后习题 8-1,8-3
- java语言程序设计第十版(Introduce to java 10th) 课后习题 chapter7-21
- 小甲鱼python零基础课后习题001我和Python的第一次亲密接触