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.

 f = int(input("From: "))
t = int(input("To: "))
i = int(input("Increment: "))
for n in range(f, t+1, i):
print(n, end=', ')

8–4. 素数. 我们在本章已经给出了一些代码来确定一个数字的最大约数或者它是否是一个
素数. 请把相关代码转换为一个返回值为布尔值的函数,函数名为 isprime() . 如果输入的是一个
素数, 那么返回 True , 否则返回 False .

 from math import sqrt

 def isprinme(num):
if num == 1:
return False
for i in range(2, int(sqrt(num)) + 1):
if num % i == 0:
return False
return True if __name__ == '__main__':
num = int(input("输入数字: "))
print(isprinme(num))

8–5. 约数. 完成一个名为 getfactors() 的函数. 它接受一个整数作为参数, 返回它所有
约数的列表, 包括 1 和它本身

 def getfactors(num):

     return [i for i in range(1, num+1) if num % i==0]

 if __name__ == '__main__':
num = int(input("输入数字: "))
print(getfactors(num))

8–6. 素因子分解. 以刚才练习中的 isprime() 和 getfactors() 函数为基础编写一个函
数, 它接受一个整数作为参数, 返回该整数所有素数因子的列表. 这个过程叫做求素因子分解, 它
输出的所有因子之积应该是原来的数字. 注意列表里可能有重复的元素. 例如输入 20 , 返回结果
应该是 [2, 2, 5] .

 from math import sqrt

 def isprinme(num):
"""质数"""
if num == 1:
return False
for i in range(2, int(sqrt(num)) + 1):
if num % i == 0:
return False
return True def getfactors(num):
"""约数"""
return [i for i in range(1, num+1) if num % i==0] def prime_factors(num):
"""素因子"""
res = []
if isprinme(num):
res = [1, num]
else:
temp = getfactors(num)
for i in temp:
if isprinme(i):
while num > 0 and num % i ==0:
res.append(i)
num //= i
return res if __name__ == '__main__':
num = int(input("输入数字: "))
print(prime_factors(num))

8–7. 全数. 完全数被定义为这样的数字: 它的约数(不包括它自己)之和为它本身. 例如: 6
的约数是 1, 2, 3, 因为 1 + 2 + 3 = 6 , 所以 6 被认为是一个完全数. 编写一个名为 isperfect()

的函数, 它接受一个整数作为参数, 如果这个数字是完全数, 返回 1 ; 否则返回 0 .

 def getfactors(num):
"""约数"""
return [i for i in range(1, num) if num % i==0] def isperfect(num):
"""完全数"""
app = getfactors(num)
if sum(app) == num:
return 1
return 0 if __name__ == '__main__':
num = int(input("输入数字: "))
print(isperfect(num))

8–8. 阶乘. 一个数的阶乘被定义为从 1 到该数字所有数字的乘积. N 的阶乘简写为 N! .
写一个函数, 指定N, 返回 N! 的值.

 def factorial(N):
if N == 1:
return N
return N * factorial(N-1) if __name__ == '__main__':
N = int(input("输入数字: "))
print(factorial(N))

8–9. Fibonacci 数列. Fibonacci 数列形如 1, 1, 2, 3, 5, 8, 13, 21, 等等. 也就是说,
下一个值是序列中前两个值之和. 写一个函数, 给定 N , 返回第 N 个 Fibonacci 数字. 例如, 第
1 个 Fibonacci 数字是 1 , 第 6 个是 8 .

 def sequence(num):
if num == 1 or num == 2:
return 1
return sequence(num - 1) + sequence(num - 2) if __name__ == '__main__':
num = int(input("输入数字: "))
print(sequence(num))

8–10. 文本处理. 统计一句话中的元音, 辅音以及单词(以空格分割)的个数. 忽略元音和
辅音的特殊情况, 如 "h", "y", "qu" 等. 附加题: 编写处理这些特殊情况的代码.

 import string

 def count(sentence):

     words = sentence.split(' ')
word_cnt = len(words)
vowel_cnt, con_cnt = 0, 0
for word in words:
for ch in word:
if ch in 'aeiouAEIOU':
vowel_cnt += 1
elif ch in string.ascii_letters:
con_cnt += 1 return ('元音:', vowel_cnt, '辅音:', con_cnt, '单词:', word_cnt) if __name__ == '__main__':
sentence = input("Sentence: ")
print(count(sentence))

8–12. (整型)位操作。编写一个程序,用户给出起始和结束数字后给出一个下面的表格,

分别显示两个数字间的十进制、二进制、八进制和十六进制。如果字符是可打印的ASCII字符,

也要打印出来,如果没有一个是可打印的就省略ASCII那一栏的表头。

 def format(start, end):
print("十进制\t\t二进制\t\t八进制\t\t十六进制\t\tASCII"
"\n-----------------------------------------------------------------")
for i in range(start, end):
if chr(i):
asc = chr(i)
else:
asc = None
print("%4s\t%10s\t%9s\t%10s\t%10s" % (i, bin(i), oct(i), hex(i), asc)) if __name__ == '__main__':
start = int(input("输入起始值:"))
end = int(input("输入结束值:"))
format(start, end)

python核心编程2 第八章 练习的更多相关文章

  1. 《Python核心编程》 第八章 条件和循环

    8–1.条件语句. 请看下边的代码 # statement A if x > 0: # statement B pass elif x < 0: # statement C pass el ...

  2. python核心编程(第二版)习题

    重新再看一遍python核心编程,把后面的习题都做一下.

  3. Python核心编程这本书的一些错误

    <Python核心编程第二版>这本书比<Python基础教程第二版修订版>详细很多,丰富了很多细节,虽然它是一本经典的入门书,但我发现还是存在一些明显的错误.在面向对象编程这一 ...

  4. Python核心编程-描述符

    python中,什么描述符.描述符就是实现了"__get__"."__set__"或"__delete__" 方法中至少一个的对象.什么是非 ...

  5. Python核心编程-闭包

    百度搜了一下闭包的概念:简而言之,闭包的作用就是在外部函数执行完并返回后,闭包使得收机制不会收回函数所占用的资源,因为内部函数的执行需要依赖外函数中的变量.这是对闭包作用的非常直白的描述,不专业也不严 ...

  6. python核心编程第二版笔记

    python核心编程第二版笔记由网友提供:open168 python核心编程--笔记(很详细,建议收藏) 解释器options:1.1 –d   提供调试输出1.2 –O   生成优化的字节码(生成 ...

  7. 学习《Python核心编程》做一下知识点提要,方便复习(一)

    学习<Python核心编程>做一下知识点提要,方便复习. 计算机语言的本质是什么? a-z.A-Z.符号.数字等等组合成符合语法的字符串.供编译器.解释器翻译. 字母组合后产生各种变化拿p ...

  8. python核心编程--笔记

    python核心编程--笔记 的解释器options: 1.1 –d   提供调试输出 1.2 –O   生成优化的字节码(生成.pyo文件) 1.3 –S   不导入site模块以在启动时查找pyt ...

  9. Python核心编程第二版(中文).pdf 目录整理

    python核心编程目录 Chapter1:欢迎来到python世界!-页码:7 1.1什么是python 1.2起源  :罗萨姆1989底创建python 1.3特点 1.3.1高级 1.3.2面向 ...

随机推荐

  1. pat1082. Read Number in Chinese (25)

    1082. Read Number in Chinese (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yu ...

  2. 存储过程 返回值 procedure return values

    存储过程有三种返回: 1. 用return返回int型数据 2. 用返回参数返回结果,可以返回各种数据类型(通过游标来循环查询结果每一行) 3. 直接在存储过程中用select返回结果集,可以是任意的 ...

  3. Python函数(1)

    一.Python函数介绍 函数时组织好的,可重复的,用来实现单一,或相关联功能的代码段. 函数的使用原则时先定义,后调用:事先准备工具的过程即函数的定义,遇到应用场景拿来当工具用即函数的调用. 函数的 ...

  4. BZOJ3329: Xorequ(二进制数位dp 矩阵快速幂)

    题意 题目链接 Sol 挺套路的一道题 首先把式子移一下项 \(x \oplus 2x = 3x\) 有一件显然的事情:\(a \oplus b \leqslant c\) 又因为\(a \oplus ...

  5. jquery-fullpage插件

    jquery fullpage.js全屏滚动插件/jquery-easing插件 // 前端自动化工具安装插件 在页面引入: <link rel="stylesheet" h ...

  6. [Maven]Eclipse集成遇到的问题

    当maven项目导入到eclipse中后使用eclipse提供的maven命令执行任意一个出现 Exception in thread "main" java.lang.Unsup ...

  7. Spark Job调度

    Spark Job调度 1.概览 Spark有几种用于在计算之间调度资源的工具.首先,回想一下,如集群模式概述中所述,每个Spark应用程序(SparkContext的实例)都运行一组独立的execu ...

  8. 什么是permit-inside功能

    若内网有一台服务器映射成为一个公网IP地址,并且将该公网IP注册至一个域名中.此时内网用户通过直接输入域名访问该服务器,域名服务器将该服务器的地址解析为已经注册的公网IP地址.默认情况下,当内网用户通 ...

  9. 关于ASP.NET页面事件的知识点

    ASP是动态服务器页面(ActiveServerPage)的英文缩写,是微软公司开发的代替CGI脚本程序的一种应用,它可以与数据库和其它程序进行交互,是一种简单.方便的编程工具.那么关于ASP.NET ...

  10. phpstorm 2017.1 激活

    打开网址 http://idea.lanyus.com/ 选择获取注册码,复制生成的验证码 安装完成后,打开软件,依次选择菜单栏 Help -> Register-> Activation ...