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