-
判断101-200之间有多少个素数,并输出所有素数。
count = 0 for i in range(101, 200): for j in range(2, int(i**0.5) + 1): if i % j == 0: break else: print(i) count += 1 print('一共有', count, '个素数')
-
求整数1~100的累加值,但要求跳过所有个位为3的数。
s = 0 for i in range(0, 101): if i % 10 == 3: s = s else: s += i print(s)
-
有⼀分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的第20个分数
k = 1 i = 1 j = 2 while k < 20: s = j - i i = j j = i + j - s k += 1 print('第20个分数为', j, '/', i)
-
写程序计算 n 的阶乘 n! 的结果
n = int(input('输入正整数n')) s = 1 for i in range(1, n+1): s *= i print(n, '!', '的结果为', s)
-
求1+2!+3!+…+20!的和
s = 0 for i in range(1, 21): n = 1 for j in range(1, i+1): n *= j s += n print('1+2!+3!+...+20!的和为', s)
-
写程序求表达式 a + aa + aaa + aaaa+ … 的结果,其中a是1~9的数字,求和的项数用n来控制。(a和n可以用变量来表示)
例如:a为3, n为5的时候: 3 + 33 + 333 + 3333 + 33333
a = int(input('请输入1~9的任意0整数:')) n = int(input('请输入任意正整数:')) s = a for i in range(1, n): a = a*10 + a % 10 s += a print(s)
-
控制台输出三角形
a.根据n的值的不同,输出相应的形状 n = 5时 n = 4 ***** **** **** *** *** ** ** * * b.根据n的值的不同,输出相应的形状(n为奇数) n = 5 n = 7 * * *** *** ***** ***** ******* c. 根据n的值的不同,输出相应的形状 n = 4 1 121 12321 1234321 n = 5 1 121 12321 1234321 123454321
n = int(input('请输入任意正整数')) for i in range(n): print('' '') for j in range(n - i): print('*', end='') print('') n = int(input('请输入任意奇数')) a = int((n + 1) / 2) for i in range(a): print('' '') for j in range(int((n - (2 * i + 1)) / 2)): print(' ', end='') for k in range(2 * i + 1): print('*', end='') for m in range(int((n - (2 * i + 1)) / 2)): print(' ', end='') print('') n = int(input('输入任意正整数')) for i in range(n): t = 1 print('' '') for j in range(int(((2 * n - 1) - (2 * i + 1)) / 2)): print(' ', end='') for k in range(int((2 * i + 1) / 2)): print(t, end='') t += 1 for x in range(int((2 * i + 2) / 2)): print(t, end='') t -= 1 for m in range(int(((2 * n - 1) - (2 * i + 1)) / 2)): print(' ', end='') print('')
-
小明单位发了100元的购物卡,小明到超市买三类洗化用品,洗发水(15元),香皂(2元),牙刷(5元)。要把100元正好花掉,可有哪些购买结合?
a = int(100 / 15) b = int(100 / 2) c = int(100 / 5) for i in range(a): for j in range(b): for k in range(c): if 15 * i + 2 * j + 5 * k == 100: print('可以买洗发水:', i, '个', '香皂', j, '个', '牙刷', k, '个')
-
一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?
thk = 0.08 * 10 ** (-3) i = 2 count = 0 while thk < 8848.13: thk *= i count += 1 print('需要对折', count, '次')
-
古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
mon = int(input('请输入月数:')) num = 2 i = 0 if mon <= 2: print('本月兔子总数为:', num, '只') else: num_1 = 2 num_2 = 2 while i <= mon - 3: num = num_1 + num_2 # 2个月之后,每个月兔子数等于前两个月的兔子数之后 num_1 = num_2 num_2 = num i += 1 print('本月兔子总数为:', num, '只')
-
将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。
num = int(input('任意正整数')) print(num, '=', end='') i = 2 j = 2 count1 = 0 count2 = 0 n = num while i <= num: if num % i == 0: count1 += 1 num = num // i i = 2 else: i += 1 # 找出一共可以分解为几个数 while j <= n: if n % j == 0: print(j, end='') count2 += 1 if count2 < count1: # 最后一个数之前每打印一个数,都打印一个x print('x', end='') n = n // j j = 2 else: j += 1
-
某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值
num = int(input('请输入四位数的整数:')) x = 0 y = 0 i = num % 10 # 第四位的数字 j = num % 100 // 10 # 第三位的数字 k = num % 1000 // 100 # 第二位的数字 n = num // 1000 # 第一位的数字 i = (i + 5) % 10 # 第二步后新的第四位的数字 j = (j + 5) % 10 # 第二步后新的第三位的数字 k = (k + 5) % 10 # 第二步后新的第二位的数字 n = (n + 5) % 10 # 第二步后新的第一位的数字 x = i i = n n = x # 交换第一位和第四位数 y = j j = k k = y # 交换第二位和第三位数 print(n, k, j, i, sep='')
-
本金10000元存入银行,年利率是千分之三。每过1年,将本金和利息相加作为新的本金。计算5年后,获得的本金是多少。
i = 0 x = 10000 while i < 5: p = x * 0.003 x += p i += 1 print('五年后,新的本金为:', x, '元')
-
输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)
num = int(input('输入任意整数')) s = 0 while num % 10 != 0: s += num % 10 num = num // 10 print('该整数各位上数字的和为:', s)
-
求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)
a = int(input('请输入任意正整数')) b = int(input('请输入另一不相同的任意正整数')) if a < b: m = b n = a else: m = a n = b # 保证m为大数,n为小数 x = 1 for i in range(1, n+1): if m % i == 0 and n % i == 0: if i >= x: # 将大值赋给x,保证最后输出为最大公约数 x = i print('最大公约数为:', x) for j in range(m, m*n+1): if j % m == 0 and j % n == 0: print('最小公倍数为:', j) break
周末作业-循环练习题
最新推荐文章于 2023-10-22 17:39:15 发布