-
判断101-200之间有多少个素数,并输出所有素数。
count = 0 for x in range(101, 200): for y in range(2, int(x**0.5)+1): if x % y == 0: break else: print(x, end=' ') count += 1 print('\n一共有:', count, '个素数')
-
求整数1~100的累加值,但要求跳过所有个位为3的数。
sum1 = 0 for x in range(1, 100): if x % 10 != 3: sum1 += x print('累加值:', sum1)
-
有⼀分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的第20个分数
value1 = 1 value2 = 2 for x in range(1, 20): value1, value2 = value2, value1+value2 print(value2, '/', value1, sep='')
-
写程序计算 n 的阶乘 n! 的结果
res = 1 n = int(input('请输入n的值:')) for x in range(1, n + 1): res *= x print(n, '! = ', res, sep='')
-
求1+2!+3!+…+20!的和
sum1 = 0 for x in range(1, 21): factorial = 1 for y in range(1, x + 1): factorial *= y sum1 += factorial print('和:', sum1)
-
写程序求表达式 a + aa + aaa + aaaa+ … 的结果,其中a是1~9的数字,求和的项数用n来控制。(a和n可以用变量来表示)
例如:a为3, n为5的时候: 3 + 33 + 333 + 3333 + 33333
a = int(input('请输入a的值(1~9):')) n = int(input('请输入n的值:')) res = 0 for x in range(1, n + 1): sum1 = 0 for y in range(x): sum1 += a * 10 ** y print(sum1, end=' + ') res += sum1 print('\b\b=', res)
-
控制台输出三角形
a.根据n的值的不同,输出相应的形状 n = 5时 n = 4 ***** **** **** *** *** ** ** * * n = int(input('请输入n的值:')) for x in range(n, 0, -1): for y in range(x): print('*', end='') print() b.根据n的值的不同,输出相应的形状(n为奇数) n = 5 n = 7 * * *** *** ***** ***** ******* n = int(input('请输入n的值:')) if n % 2: for x in range(1, n+1, 2): space = (n - x) // 2 for _ in range(space): print(' ', end='') for _ in range(x): print('*', end='') print() else: print('该数不符合要求') c. 根据n的值的不同,输出相应的形状 n = 4 1 121 12321 1234321 n = 5 1 121 12321 1234321 123454321 n = int(input('请输入n的值:')) for x in range(1, n+1): space = n - x for y in range(1, space+1): print(' ', end='') for y in range(1, x): print(y, end='') for y in range(x, 0, -1): print(y, end='') print()
-
小明单位发了100元的购物卡,小明到超市买三类洗化用品,洗发水(15元),香皂(2元),牙刷(5元)。要把100元正好花掉,可有哪些购买结合?
for money1 in range(0, 101, 15): for money2 in range(0, 101, 5): if money1 + money2 > 100: break money3 = 100 - money1 - money2 if money3 % 2 == 0: print('洗发水:', money1 // 15, '\t香皂:', money3 // 2, '\t牙刷:', money2 // 5)
-
一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?
paper_thickness = 0.08 height = 8848130 count = 0 while paper_thickness * 2**count < height: count += 1 print('对折次数:', count)
-
古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
month = int(input('请输入月数:')) pre1 = 1 pre2 = 1 for num in range(2, month): pre1, pre2 = pre2, pre2+pre1 print('兔子总数是:', pre2, '对')
-
将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。
num = int(input('请输入一个正整数:')) print(num, '=', sep='', end='') while True: for x in range(2, num+1): if num % x == 0: num = num // x print(x, 'x', sep='', end='') break else: break print('\b') # 退格符,去掉多余的x # 优化 num = int(input('请输入一个正整数:')) print(num, '=', sep='', end='') while True: for x in range(2, int(num**0.5)+1): if num % x == 0: num = num // x print(x, 'x', sep='', end='') break else: print(num) break
-
某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值
sum1 = 0 num = int(input('请输入一个四位数:')) for x in range(0, 4): # num // 10**x % 10 通用取位数公式,x为0取个位,x为1取十位,以次类推 # 10***(3-x) 表示将位置互换,x为0时,个位数乘以1000,个位数变换到千位,以次类推 temp = (num // 10**x % 10 + 5) % 10 * 10**(3-x) sum1 += temp print(sum1)
-
将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。
num = int(input('请输入一个正整数:')) print(num, '=', sep='', end='') while True: for x in range(2, num+1): if num % x == 0: num = num // x print(x, 'x', sep='', end='') break else: break print('\b') # 退格符,去掉多余的x
-
本金10000元存入银行,年利率是千分之三。每过1年,将本金和利息相加作为新的本金。计算5年后,获得的本金是多少。
principal = 10000 interest_rate = 3 / 1000 for x in range(5): principal += principal*interest_rate print('本金是:', principal)
-
输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)
num = abs(int(input('请输入一个整数:'))) num_len = len(str(num)) # 计算输入整数有多少位 sum1 = 0 for x in range(0, num_len): sum1 += num // 10**x % 10 print('和是:', sum1)
-
求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)
num1 = int(input('请输入值1:')) num2 = int(input('请输入值2:')) for x in range(min(num1, num2), 0, -1): if num1 % x == 0 and num2 % x == 0: print('最大公约数是:', x) break for x in range(max(num1, num2), num1 * num2 + 1): if x % num1 == 0 and x % num2 == 0: print('最小公倍数是:', x) break # 方法二: num1 = int(input('请输入值1:')) num2 = int(input('请输入值2:')) commons = [] # 用于保存num1和num2的公共因数 singles = [] # 用于保存num1和num2的各自不同的因数 while True: for x in range(2, int(min(num1, num2))+1): if num1 % x == 0 and num2 % x == 0: num1 = num1 // x num2 = num2 // x commons.append(x) break else: print('num1:', num1, ',num2:', num2) singles.append(num1) singles.append(num2) break max_gongyue = 1 # 最大公因数本质是公共因数的乘积 for x in commons: max_gongyue *= x min_gongbei = max_gongyue for x in singles: min_gongbei *= x print('最大公约数:', max_gongyue, ',最小公倍数:', min_gongbei)
周末作业-循环练习题(1)
最新推荐文章于 2023-08-05 22:25:32 发布