练习11:

题目:

古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

分析:

兔子的规律为数列1,1,2,3,5,8,13,21....

程序:

f1 = 1
f2 = 1
for i in range(1, 22):
print('%d %d' % (f1, f2))
if (i % 3) == 0:
print()
f1 = f1 + f2
f2 = f1 + f2

输出结果:

1 1
2 3
5 8 13 21
34 55
89 144 233 377
610 987
1597 2584 4181 6765
10946 17711
28657 46368 75025 121393
196418 317811
514229 832040 1346269 2178309
3524578 5702887
9227465 14930352 24157817 39088169
63245986 102334155
165580141 267914296

练习12:

题目:

判断101-200之间有多少个素数,并输出所有素数。

分析:

判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。      

程序:

h = 0
leap = 1
from math import sqrt
from sys import stdout for m in range(101, 201):
k = int(sqrt(m + 1))
for i in range(2, k + 1):
if m % i == 0:
leap = 0
break
if leap == 1:
print('%-4d' % m)
h += 1
if h % 10 == 0:
print()
leap = 1
print('The total is %d' % h)

输出结果:

101
103
107
109
113
127
131
137
139
149 151
157
163
167
173
179
181
191
193
197 199
The total is 21

练习13:

题目:

打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。

分析:

利用for循环控制100-999个数,每个数分解出个位,十位,百位。

程序:

for n in range(100, 1000):
i = n // 100
j = n // 10 % 10
k = n % 10
if n == i ** 3 + j ** 3 + k ** 3:
print(n)

输出结果:

153
370
371
407

练习14:

题目:

将一个正整数分解质因数。例如:输入90,打印出90=233*5。

分析:

对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:

(1) 如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。

(2) 如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。

(3) 如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

程序:

def reduceNum(n):
print('{} = '.format(n),end="")
if not isinstance(n, int) or n <= 0 :
print('请输入一个正确的数字 !')
exit(0)
elif n in [1] :
print('{}'.format(n))
while n not in [1] : # 循环保证递归
for index in range(2, n + 1) :
if n % index == 0:
n //= index # n 等于 n//index
if n == 1:
print(index)
else : # index 一定是素数
print('{} * '.format(index),end="")
break
reduceNum(90)
reduceNum(100)

输出结果:

90 = 2 * 3 * 3 * 5
100 = 2 * 2 * 5 * 5

练习15:

题目:

利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。

分析:

(a>b)?a:b这是条件运算符的基本例子。

程序:

score = int(input('输入分数:\n'))
if score >= 90:
grade = '优秀'
elif score >= 60:
grade = '良好'
else:
grade = '差劲'
print('分数:%d 等级:%s' % (score, grade))

输出结果:

输入分数:
98
分数:98 等级:优秀

练习16:

题目:

输出指定格式的日期。

分析:

使用 datetime 模块。

程序:

import datetime
if __name__ == '__main__':
# 输出今日日期,格式为 dd-mm-yyyy。更多选项可以查看 strftime() 方法
print(datetime.date.today().strftime('%d-%m-%Y'))
# 创建日期对象
date1 = datetime.date(1941, 1, 5)
print(date1.strftime('%d-%m-%Y'))
# 日期算术运算
date2 = date1 + datetime.timedelta(days=1)
print(date2.strftime('%d-%m-%Y'))
# 日期替换
date3 = date1.replace(year=date1.year + 1)
print(date3.strftime('%d-%m-%Y'))

输出结果:

23-03-2019
05-01-1941
06-01-1941
05-01-1942

练习17:

题目:

输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

分析:

利用 while 或 for 语句,条件为输入的字符不为 '\n'。

程序:

import string

s = input('请输入一个字符串:\n')
letters = 0
space = 0
digit = 0
others = 0
i = 0
while i < len(s):
c = s[i]
i += 1
if c.isalpha():
letters += 1
elif c.isspace():
space += 1
elif c.isdigit():
digit += 1
else:
others += 1
print('char = %d,space = %d,digit = %d,others = %d' % (letters, space, digit, others))

输出结果:

请输入一个字符串:
qw12 3..?/
char = 2,space = 2,digit = 3,others = 4

练习18:

题目:

求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制。

分析:

关键是计算出每一项的值。

程序:

from functools import reduce
Tn = 0
Sn = []
n = int(input('n = '))
a = int(input('a = '))
for count in range(n):
Tn = Tn + a
a = a * 10
Sn.append(Tn)
print(Tn)
Sn = reduce(lambda x, y: x + y, Sn)
print("计算和为:", Sn)

输出结果:

n = 5
a = 2
2
22
222
2222
22222
计算和为: 24690

练习19:

题目:

一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6=1+2+3.编程找出1000以内的所有完数。

程序:

from sys import stdout

for j in range(2, 1001):
k = []
n = -1
s = j
for i in range(1, j):
if j % i == 0:
n += 1
s -= i
k.append(i) if s == 0:
print(j)
for i in range(n):
stdout.write(str(k[i]))
stdout.write(' ')
print(k[n])

输出结果:

6
1 2 3
28
1 2 4 7 14
496
1 2 4 8 16 31 62 124 248

练习20:

题目:

一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?

程序:

tour = []
height = [] hei = 100.0 # 起始高度
tim = 10 # 次数 for i in range(1, tim + 1):
# 从第二次开始,落地时的距离应该是反弹高度乘以2(弹到最高点再落下)
if i == 1:
tour.append(hei)
else:
tour.append(2 * hei)
hei /= 2
height.append(hei) print('总高度:tour = {0}'.format(sum(tour)))
print('第10次反弹高度:height = {0}'.format(height[-1]))

输出结果:

总高度:tour = 299.609375
第10次反弹高度:height = 0.09765625

Python3.x 基础练习题100例(11-20)的更多相关文章

  1. Python3.x 基础练习题100例(01-10)

    练习01: 题目: 有四个数字:1.2.3.4,能组成多少个互不相同且无重复数字的三位数?各是多少? 分析: 可填在百位.十位.个位的数字都是1.2.3.4.组成所有的排列后再去 掉不满足条件的排列. ...

  2. Python3.x 基础练习题100例(41-50)

    练习41: 题目: 模仿静态变量的用法. 程序: def varfunc(): var = 0 print('var = %d' % var) var += 1 if __name__ == '__m ...

  3. Python3.x 基础练习题100例(51-60)

    练习51: 题目: 学习使用 按位与(&) . 分析: 0&0=0; 0&1=0; 1&0=0; 1&1=1. 程序: if __name__ == '__ma ...

  4. Python3.x 基础练习题100例(31-40)

    练习31: 题目: 请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母. 分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或if语句判断第二个字母. 程序 ...

  5. Python3.x 基础练习题100例(21-30)

    练习21: 题目: 猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个.以后每天早上都吃了前 一天剩下的一半零一个.到第10天早上 ...

  6. Python3.x 基础练习题100例(81-90)

    练习81: 题目: 809??=800??+9?? 其中??代表的两位数, 809??为四位数,8??的结果为两位数,9??的结果为3位数.求??代表的两位数,及809*??后的结果. 程序: a = ...

  7. Python3.x 基础练习题100例(91-100)

    练习91: 题目: 时间函数举例1. 程序: if __name__ == '__main__': import time print (time.ctime(time.time())) print ...

  8. Python3.x 基础练习题100例(61-70)

    练习61: 题目: 打印出杨辉三角形. 程序: if __name__ == '__main__': a = [] for i in range(10): a.append([]) for j in ...

  9. Python3.x 基础练习题100例(71-80)

    练习71: 题目: 编写input()和output()函数输入,输出5个学生的数据记录. 程序: N = 5 # stu # num : string # name : string # score ...

随机推荐

  1. E - Period(KMP中next数组的运用)

    一个带有 n 个字符的字符串 s ,要求找出 s 的前缀中具有循环结构的字符子串,也就是要输出具有循环结构的前缀的最后一个数下标与其对应最大循环次数.(次数要求至少为2) For each prefi ...

  2. Codeforces Round #626 (Div. 2)

    Contest Info Practice Link Solved A B C D E F 4/6 O Ø Ø  Ø  Ø  - O 在比赛中通过 Ø 赛后通过 ! 尝试了但是失败了 - 没有尝试 S ...

  3. 【洛谷 p3372】模板-线段树 1(数据结构--线段树)

    题目:已知一个数列,你需要进行下面两种操作:1.将某区间每一个数加上x:2.求出某区间每一个数的和. 解法:如题,模版题.需要加上 lazy 标记,也就是我的 upd.lazy 标记的思路就是对一个结 ...

  4. hdu1541 Stars

    Problem Description Astronomers often examine star maps where stars are represented by points on a p ...

  5. UVA-11019 二维哈希算法

    UVA-11019 题意: 就是给你AB两个字符矩阵,问你B矩阵在A矩阵中的出现次数. 题解:  参考链接:https://blog.csdn.net/qq_38891827/java/article ...

  6. JSR-303 实现参数校验

    参考 1. 什么是JSR-303 JSR-303 是 JAVA EE 6 中的一项子规范,叫做 Bean Validation,官方参考实现是Hibernate Validator. 此实现与 Hib ...

  7. 自动生成requirements.txt

    Python 自动生成当前项目的requirements.txt 通常我们开发一个python项目时都会用conda 或者 virtualenv 等虚拟环境管理工具来创建一个虚拟环境,在这个虚拟环境中 ...

  8. MySQL 回表查询 & 索引覆盖优化

    回表查询 先通过普通索引的值定位聚簇索引值,再通过聚簇索引的值定位行记录数据 建表示例 mysql> create table user( -> id int(10) auto_incre ...

  9. Java之一个整数的二进制中1的个数

    这是今年某公司的面试题: 一般思路是:把整数n转换成二进制字符数组,然后一个一个数: private static int helper1(int i) { char[] chs = Integer. ...

  10. mybatis(六)插件机制及分页插件原理

    转载:https://www.cnblogs.com/wuzhenzhao/p/11120848.html MyBatis 通过提供插件机制,让我们可以根据自己的需要去增强MyBatis 的功能.需要 ...