-
判断101-200之间有多少个素数,并输出所有素数。
count = 0 su = [] for i in range(101, 200): su.append(i) for j in range(2, i): if i % j == 0: su.remove(i) break else: count += 1 print('素数一共有', count, '个') print(su) # 素数一共有 21 个 # [101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199]
-
求整数1~100的累加值,但要求跳过所有个位为3的数。
sum = 0 for i in range(1, 100): if i % 10 == 3: sum += 0 else: sum += i print(sum) # 4470
-
有⼀分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的第20个分数
fz1 = 2 fz2 = 3 fm1 = 1 fm2 = 2 for i in range(2, 20): n = fz1 + fz2 m = fm1 + fm2 fz1 = fz2 fm1 = fm2 fz2 = n fm2 = m print(fz2, '/', fm2) # 17711 / 10946
-
写程序计算 n 的阶乘 n! 的结果
n = int(input('请输入一个正整数:')) result = 1 for i in range(1,n+1): result *= i print(result)
-
求1+2!+3!+…+20!的和
sum = 0 for i in range(1, 21): result = 1 for j in range(1, i+1): result *= j sum += result print(sum) # 2561327494111820313
-
写程序求表达式 a + aa + aaa + aaaa+ … 的结果,其中a是1~9的数字,求和的项数用n来控制。(a和n可以用变量来表示)
例如:a为3, n为5的时候: 3 + 33 + 333 + 3333 + 33333
a = b = 3 n = 5 s = 0 for i in range(n-1): s += a a = a*10 + b print(s) # 3702
-
控制台输出三角形
a. 根据n的值的不同,输出相印的形状 n = 5 ***** **** *** ** * n = 5 for i in range(n, 0, -1): print('*'*(i)) b.根据n的值的不同,输出相应的形状(n为奇数) n = 5 n = 7 * * *** *** ***** ***** ******* n = int(input('请输入一个奇数:')) for i in range(1, n+1, 2): m = int((n-i)/2) print(' ' * m, '*' * i, ' ' * m) c. 根据n的值的不同,输出相应的形状 n = 4 1 121 12321 1234321 n = 5 1 121 12321 1234321 123454321 n = int(input('请输入一个数:')) num = 1 count = 0 list = [1] # 获取第n个奇数 while count < n-1: num += 2 count += 1 list.append(num) print(num) print(list) # 输出数字三角形 for i in range(n): s = '' s += str(i+1) l = i+1 while l != 1: s = s + str(l-1) s = str(l-1) + s l -= 1 # print(s) for j in range(1, num+1, 2): blank = int((num-list[i])/2) print(' ' * blank, s, ' ' * blank)
-
小明单位发了100元的购物卡,小明到超市买三类洗化用品,洗发水(15元),香皂(2元),牙刷(5元)。要把100元正好花掉,可有哪些购买结合?
for i in range(100//15): for j in range(50): for k in range(20): if 15*i + 2*j +5*k == 100: print('洗发水:',i,'香皂:', j, '牙刷', k) """ 洗发水: 0 香皂: 5 牙刷 18 洗发水: 0 香皂: 10 牙刷 16 洗发水: 0 香皂: 15 牙刷 14 洗发水: 0 香皂: 20 牙刷 12 洗发水: 0 香皂: 25 牙刷 10 洗发水: 0 香皂: 30 牙刷 8 洗发水: 0 香皂: 35 牙刷 6 洗发水: 0 香皂: 40 牙刷 4 洗发水: 0 香皂: 45 牙刷 2 洗发水: 1 香皂: 0 牙刷 17 洗发水: 1 香皂: 5 牙刷 15 洗发水: 1 香皂: 10 牙刷 13 洗发水: 1 香皂: 15 牙刷 11 洗发水: 1 香皂: 20 牙刷 9 洗发水: 1 香皂: 25 牙刷 7 洗发水: 1 香皂: 30 牙刷 5 洗发水: 1 香皂: 35 牙刷 3 洗发水: 1 香皂: 40 牙刷 1 洗发水: 2 香皂: 0 牙刷 14 洗发水: 2 香皂: 5 牙刷 12 洗发水: 2 香皂: 10 牙刷 10 洗发水: 2 香皂: 15 牙刷 8 洗发水: 2 香皂: 20 牙刷 6 洗发水: 2 香皂: 25 牙刷 4 洗发水: 2 香皂: 30 牙刷 2 洗发水: 2 香皂: 35 牙刷 0 洗发水: 3 香皂: 0 牙刷 11 洗发水: 3 香皂: 5 牙刷 9 洗发水: 3 香皂: 10 牙刷 7 洗发水: 3 香皂: 15 牙刷 5 洗发水: 3 香皂: 20 牙刷 3 洗发水: 3 香皂: 25 牙刷 1 洗发水: 4 香皂: 0 牙刷 8 洗发水: 4 香皂: 5 牙刷 6 洗发水: 4 香皂: 10 牙刷 4 洗发水: 4 香皂: 15 牙刷 2 洗发水: 4 香皂: 20 牙刷 0 洗发水: 5 香皂: 0 牙刷 5 洗发水: 5 香皂: 5 牙刷 3 洗发水: 5 香皂: 10 牙刷 1 """
-
一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?
# 将毫米换算为米 h = 0.08 * 10 ** -3 count = 0 while h < 8848.13: h *= 2 count += 1 print(count) # 27
-
古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
n = int(input('到第几个月:')) m1 = 1 # 第一个月有一对兔子 m2 = 1 # 第二个月有一对兔子 data1 = {'1': m1, '2': m2} # 存放每个月的兔子对数 for i in range(3, n+1): data1[str(i)] = data1[str(i-1)] + data1[str(i-2)] print(data1)
{‘1’: 1, ‘2’: 1, ‘3’: 2, ‘4’: 3, ‘5’: 5, ‘6’: 8, ‘7’: 13, ‘8’: 21, ‘9’: 34, ‘10’: 55, ‘11’: 89, ‘12’: 144, ‘13’: 233, ‘14’: 377, ‘15’: 610, ‘16’: 987, ‘17’: 1597, ‘18’: 2584, ‘19’: 4181, ‘20’: 6765, ‘21’: 10946, ‘22’: 17711, ‘23’: 28657, ‘24’: 46368, ‘25’: 75025, ‘26’: 121393, ‘27’: 196418, ‘28’: 317811, ‘29’: 514229, ‘30’: 832040}
11. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。
```python
# 获取因数
n = int(input('请输入整数:'))
list = []
num = 1
while n > 1:
n = n // num
for i in range(2, n+1):
if n % i != 0:
continue
else:
for j in range(2, i//2):
if i % j == 0:
break
else:
list.append(i)
num = i
break
print(list)
# 输出数学式:
print(90, '=', end='')
for i in list[0:-2]:
print(i, end='x')
print(list[-1])
```
-
某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值
pwd = input('请输入传递数据:') s = '' # 中间变量 pwd_1 ='' # 存放加密后数据 for i in pwd: s += str((int(i)+5) % 10) pwd_1 = s[3]+s[2]+s[1]+s[0] print(pwd_1)
-
将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。
-
本金10000元存入银行,年利率是千分之三。每过1年,将本金和利息相加作为新的本金。计算5年后,获得的本金是多少。
ben = 10000 # 本金 r = 3**10*(-3) # 年利率 for i in range(4): ben= ben*(1+r) print(ben) # 9847486661296306598560000
-
输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)
n = input('请输入一个任意位数的整数:') num = int(n) sum =0 # 如果是负数,需要去掉负号 if num < 0: n = n[1:] n=list(n) for i in n: sum += int(i) print(sum)
-
求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)
m = int(input('请输入一位整数')) n = int(input('请输入另一位整数')) m, n = max(m, n), min(m, n) gy = 1 # 存放最大公约数 gb = m*n # 存放最小公倍数 for i in range(1, n+1): if m % i != 0 or n % i != 0: continue elif i > gy: gy = i print('最大公约数', gy) for i in range(m, m*n+1): if i % m != 0 or i % n != 0: continue elif i < gb: gb = i print('最小公倍数', gb)