《python第8章习题》
来源:互联网 发布:政府机构的域名 编辑:程序博客网 时间:2024/06/06 11:48
= =
希望今天不要补题
8–1. 条件语句. 请看下边的代码
# statement A
if x > 0:
# statement B
pass
elif x < 0:
# statement C
pass
else:
# statement D
pass
# statement E
(a)如果 x< 0 , 上面哪个语句(A, B, C, D, E)将被执行
A,C
(b)如果 x== 0 , 上面哪个居于将被执行?
ADE
(c)如果 x> 0 , 上面哪个语句将被执行?
AB
8–2. 循环. 编写一个程序, 让用户输入三个数字: (f)rom, (t)o, 和 (i)ncrement . 以 i 为步长, 从 f 计数到 t , 包括 f 和 t . 例如, 如果输入的是 f == 2, t == 26, i == 4 , 程序 将输出 2, 6, 10, 14, 18, 22, 26.
# -*- coding:utf-8 -*-start = int(raw_input("please input the start number: "))end = int(raw_input("please input the end number: "))step = int(raw_input("please input the step: "))list_number = []for i in range(start,end+1,step):list_number.append(i)print list_number
8–3. range() . 如果我们需要生成下面的这些列表, 分别需要在 range() 内建函数中提 供那些参数?
(a) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
(b) [3, 6, 9, 12, 15, 18]
(c) [-20, 200, 420, 640, 860]
# -*- coding:utf-8 -*-list_1 = []list_2 = []list_3 = []for i in range(0,10):list_1.append(i)for i in range(3,19,3):list_2.append(i)for i in range(-20,1065,220):list_3.append(i)print list_1print list_2print list_3
8–4. 素数. 我们在本章已经给出了一些代码来确定一个数字的大约数或者它是否是一个 素数. 请把相关代码转换为一个返回值为布尔值的函数,函数名为 isprime() . 如果输入的是一个 素数, 那么返回 True , 否则返回 False .
# -*- coding:utf-8 -*-import mathdef isprime(number):for i in range(1,int(math.sqrt(number))+1):if number % i == 0:flag = 0breakreturn flagif __name__ == '__main__':flag = 1number = int(raw_input("please input a number: "))flag = isprime(number)if flag == 1:print Trueelse:print False
8–5. 约数. 完成一个名为 getfactors() 的函数. 它接受一个整数作为参数, 返回它所有 约数的列表, 包括 1 和它本身,
# -*- coding:utf-8 -*-def getfactors(number):for i in range(1,number+1):if number%i==0:factors_List.append(i)if __name__ == '__main__':number = int(raw_input("please input a number: "))factors_List = []getfactors(number)print factors_List
8–6. 素因子分解. 以刚才练习中的 isprime() 和 getfactors() 函数为基础编写一个函 数, 它接受一个整数作为参数, 返回该整数所有素数因子的列表. 这个过程叫做求素因子分解, 它 输出的所有因子之积应该是原来的数字. 注意列表里可能有重复的元素. 例如输入 20 , 返回结果 应该是 [2, 2, 5] .
# -*- coding:utf-8 -*-import mathdef prime(number):global flagfor i in range(2,int(math.sqrt(number))+1):if number % i ==0:flag = 0breakreturn flagdef getprimefactors(number):global factors_listglobal flagfor i in range(2,number+1):flag = 1if number%i==0:if prime(i)==1:factors_list.append(i)product = 1for i in factors_list:product = product * iproductadd = number/productif productadd !=1:factors_list.append(productadd)print factors_listif __name__ == '__main__':flag = 1factors_list = []number = int(raw_input("please input a number: "))getprimefactors(number)
8–7. 全数. 完全数被定义为这样的数字: 它的约数(不包括它自己)之和为它本身. 例如: 6 的约数是 1, 2, 3, 因为 1 + 2 + 3 = 6 , 所以 6 被认为是一个完全数. 编写一个名为 isperfect()
的函数, 它接受一个整数作为参数, 如果这个数字是完全数, 返回 1 ; 否则返回 0 .
# -*- coding:utf-8 -*-def isperfect(number):global sumglobal list_for i in range(1,number):if number%i == 0:list_.append(i)for i in list_:sum = sum + iif sum == number:return 1else:return 0if __name__ == '__main__':sum = 0list_ = []number = int(raw_input("please input a number: "))flag = isperfect(number)print flag
8–8. 阶乘. 一个数的阶乘被定义为从 1 到该数字所有数字的乘积. N 的阶乘简写为 N! . 写一个函数, 指定 N, 返回 N! 的值.
# -*- coding:utf-8 -*-number = int(raw_input("please input a number: "))product = 1for i in range(1,number+1):product = product * iprint product
8–9. Fibonacci 数列. Fibonacci 数列形如 1, 1, 2, 3, 5, 8, 13, 21, 等等. 也就是说, 下一个值是序列中前两个值之和. 写一个函数, 给定 N , 返回第 N 个 Fibonacci 数字. 例如, 第 1 个 Fibonacci 数字是 1 , 第 6 个是 8 .
# -*- coding:utf-8 -*-list_ = []list_.append(1)list_.append(1)for i in range(2,20):list_.append(list_[i-1]+list_[i-2])print list_
- 《python第8章习题》
- 《Python核心编程》第8章 习题
- 第8章习题
- python核心编程-第8章课后习题答案
- python核心编程v2.0 第8章习题答案
- 《Python核心编程》第2章 习题
- 《Python核心编程》第3章 习题
- 《Python核心编程》第5章 习题
- 《Python核心编程》第6章 习题
- 《Python核心编程》第7章 习题
- 《Python核心编程》第9章 习题
- 《Python核心编程》第10章 习题
- 《Python核心编程》第11章 习题
- 《Python核心编程》第12章 习题
- 《Python核心编程》第6章 习题
- 《Python核心编程》第7章 习题
- 《Python核心编程》第13章 习题
- 《Python核心编程》第7章 习题
- 如何在WPS表格中同一列或同一行插入相同内容
- 简单的tomcat集群
- ubuntu 14.04-LTS 系统下安装搜狗输入法
- Linux下tomcat部署图片服务器与 vsftpd搭建
- easydss与linux内核接收网络数据流程(三)
- 《python第8章习题》
- 转载 stuts2与spring集成
- CSS3新增属性总结
- 【腾讯TMQ】【Android场景化性能测试专栏】CPU耗电性能篇
- idea 使用搜狗输入法中文卡字的问题
- [Java--常见排序算法]------堆排序 (Heap Sort)
- python的文件处理
- navicat for java设计表时长度的作用
- logstash日志分析的配置和使用