python核心编程--第八章 8.15 练习

#!/usr/bin/python
# -*- coding: utf-8 -*-

# 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(raw_input("Please input from: "))
t = int(raw_input("Please input to: "))
i = int(raw_input("Please input increment: "))

print range(f, t+i, i)
<pre name="code" class="python"># 8–2. range() . 如果我们需要生成下面的这些列表, 分别需要在 range()
#      内建函数中提供那些参数?
#      (a) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
<pre name="code" class="plain"><pre name="code" class="python">#      (b) [3, 6, 9, 12, 15, 18]

<pre name="code" class="python">#      (c) [-20, 200, 420, 640, 860]

>>> range(10)[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]>>> range(3, 19, 3)[3, 6, 9, 12, 15, 18]>>> range(-20, 861, 220)[-20, 200, 420, 640, 860]>>>



#!/usr/bin/python
# -*- coding: utf-8 -*-

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

import math

def isprime(number):
    num = int(math.sqrt(number))
    while num > 1:
        if number % num == 0:
            return False
        num -= 1
    else:
        return True

print zip(range(1, 12), (isprime(x) for x in range(1, 12)))
#!/usr/bin/python
# -*- coding: utf-8 -*-

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

def getfactors(number):
    factorslist = [number]
    num = number / 2
    while num > 0:
        if number % num == 0:
            factorslist.append(num)
        num -= 1

    return factorslist
#!/usr/bin/python
# -*- coding: utf-8 -*-

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

import math

def isprime(number):
    num = int(math.sqrt(number))
    while num > 1:
        if number % num == 0:
            return False
        num -= 1
    else:
        return True

def getfactors(number):
    factorslist = [number]
    num = number / 2
    while num > 0:
        if number % num == 0:
            factorslist.append(num)
        num -= 1

    return factorslist

def getprimefactors(number):
    primefactors = []
    if isprime(number):
        primefactors.append(number)
        return primefactors
    else:
        factors = getfactors(number)
        factor = factors[1]

        if isprime(factor):
            primefactors.append(factor)
            prime = getprimefactors(number/factor)
        elif isprime(number/factor):
            primefactors.append(number/factor)
            prime = getprimefactors(factor)
        else:
            prime = getprimefactors(factor)

        primefactors += prime
        primefactors.sort()
        return primefactors

print getprimefactors(20)
#!/usr/bin/python
# -*- coding: utf-8 -*-

# 8–7. 全数. 完全数被定义为这样的数字: 它的约数(不包括它自己)之和为它本身.
#      例如: 6的约数是 1, 2, 3, 因为 1 + 2 + 3 = 6 , 所以 6 被认为是一个完全数.
#      编写一个名为 isperfect()的函数, 它接受一个整数作为参数, 如果这个数字是完全数,
#      返回 1 ; 否则返回 0 .

def getfactors(number):
    factorslist = [number]
    num = number / 2
    while num > 0:
        if number % num == 0:
            factorslist.append(num)
        num -= 1

    return factorslist

def isperfect(number):
    factorlist = getfactors(number)
    factorlist.remove(number)
    if sum(factorlist) == number:
        return 1
    else:
        return 0

for i in range(1, 1000):
    if isperfect(i) == 1:
        print i
#!/usr/bin/python
# -*- coding: utf-8 -*-

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

def getfactorial(number):
    product = 1
    for i in range(2, number+1):
        product *= i
    else:
        return product

print getfactorial(10)

#!/usr/bin/python
# -*- coding: utf-8 -*-

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

def getfibonacci(number):
    if number == 1 or number == 2:
        return 1
    else:
        befornumbers = [1, 1]
        for i in range(3, number):
            fibonacci = sum(befornumbers)
            befornumbers.pop(0)
            befornumbers.append(fibonacci)
        else:
            return sum(befornumbers)

print getfibonacci(10)

python核心编程--第八章 8.15 练习

时间: 2024-10-13 20:13:48

python核心编程--第八章 8.15 练习的相关文章

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

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)将被执行 (b)如果 x== 0 , 上面哪个居于将被执行? (c)如果 x> 0 , 上面哪个语句将被执行? 答: a: A,C,E b: A,D,E c

python核心编程--笔记

python核心编程--笔记 的解释器options: 1.1 –d   提供调试输出 1.2 –O   生成优化的字节码(生成.pyo文件) 1.3 –S   不导入site模块以在启动时查找python路径 1.4 –v   冗余输出(导入语句详细追踪) 1.5 –m mod 将一个模块以脚本形式运行 1.6 –Q opt 除法选项(参阅文档) 1.7 –c cmd 运行以命令行字符串心事提交的python脚本 1.8 file   以给定的文件运行python脚本 2 _在解释器中表示最后

《Python核心编程》 第五章 数字 - 课后习题

课后习题  5-1 整形. 讲讲 Python 普通整型和长整型的区别. 答:普通整型是绝大多数现代系统都能识别的. Python的长整型类型能表达的数值仅仅与你机器支持的(虚拟)内存大小有关. 5-2 运算符 (a) 写一个函数,计算并返回两个数的乘积 (b) 写一段代码调用这个函数,并显示它的结果 答: def pro(a,b): p = a*b return p a = int(raw_input("a=")) b = int(raw_input("b="))

Python核心编程(第二版) 第六章习题答案

6–1.字符串.string 模块中是否有一种字符串方法或者函数可以帮我鉴定一下一个字符串是否是另一个大字符串的一部分? 答:有,string.find(str,beg,end) 6–2.字符串标识符.修改例 6-1 的 idcheck.py 脚本,使之可以检测长度为一的标识符,并且可以识别 Python 关键字,对后一个要求,你可以使用 keyword 模块(特别是 keyword.kelist)来帮你. 1 #!/usr/bin/python 2 3 import string 4 impo

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

<Python核心编程第二版>这本书比<Python基础教程第二版修订版>详细很多,丰富了很多细节,虽然它是一本经典的入门书,但我发现还是存在一些明显的错误.在面向对象编程这一章,有两个错误 1).它说任何类都有一些内置的特殊的类属性(即程序员不在类中定义也会存在),见截图 2).它说__new__方法比__init__方法更像是类的构造器.见截图: 下面进行测试: 1 #encoding:utf-8 2 class MyClass(): 3 def doPrint(self):

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

学习<Python核心编程>做一下知识点提要,方便复习. 计算机语言的本质是什么? a-z.A-Z.符号.数字等等组合成符合语法的字符串.供编译器.解释器翻译. 字母组合后产生各种变化拿python来说就是.keyword.数值,类,函数,运算符,操作符...... 1.变量不用声明,类型不固定 2.True,False = False,True读出了什么?True是个bool()类实例 3.类型工厂函数就是python2.2后把int() bool()等对数据类型操作的函数分装成对象 类 了

Python核心编程(第二版) 第五章习题答案

5-1.整型.讲讲Python普通整型和长整型的区别. 答:Python 的标准整数类型是最通用的数字类型.在大多数 32 位机器上,标准整数类型的取值范围是-2**31到 2**31-1,也就是-2,147,483,648 到 2,147,483,647.如果在 64 位机器上使用 64 位编译器编译 Python,那么在这个系统上的整数将是 64 位. Python 的长整数类型能表达的数值仅仅与你的机器支持的(虚拟)内存大小有关. 5-2.操作符.(a)写一个函数,计算并返回两个数的乘积.

Python核心编程第五章习题

Python核心编程-第五章-习题 5.1  整形,讲讲Python普通整形与长整形的区别? Python的标准整形类型是最通用的数字类型.在大多数32位机器上,标准整形类型的取值范围是-2**32-2**32 - 1. Python的长整型类型能表达的数值仅仅与你的机器支持的(虚拟)内存大小有关,换句话说,Python能轻松表达很大的整数. 长整型类型是标准整形类型的超集,当程序需要使用比标准整形更大的整型时,可以使用长整型类型,在整型值后面添加L,表示这个为长整型,3.0版本已经统一称为为整

Python核心编程(第二版) 第二章习题答案 未完待续

2-2.程序输出.阅读下面的Python脚本.#!/usr/bin/env python1 + 2 * 4(a)你认为这段脚本是用来做什么的?(b)你认为这段脚本会输出什么?(c)输入以上代码,并保存为脚本,然后运行它,它所做的与你的预期一样吗?为什么一样/不一样?(d)这段代码单独执行和在交互解释器中执行有何不同?试一下,然后写出结果.(e)如何改进这个脚本,以便它能和你想象的一样工作?答:(a)这段脚本是用来计算表达式的值(b)脚本会输出9(c)保存为脚本,运行后没有输出.和自己预期不一样.