周末作业-循环练习题(1)

  1. 判断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, '个素数')
    
  2. 求整数1~100的累加值,但要求跳过所有个位为3的数。

    sum1 = 0
    for x in range(1, 100):
        if x % 10 != 3:
            sum1 += x
    print('累加值:', sum1)
    
  3. 有⼀分数序列: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='') 
    
  4. 写程序计算 n 的阶乘 n! 的结果

    res = 1
    n = int(input('请输入n的值:'))
    for x in range(1, n + 1):
        res *= x
    print(n, '! = ', res, sep='')
    
  5. 求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)
    
  6. 写程序求表达式 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)
    
  7. 控制台输出三角形

    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()
    
  8. 小明单位发了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)
    
  9. 一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?

    paper_thickness = 0.08
    height = 8848130
    count = 0
    while paper_thickness * 2**count < height:
        count += 1
    print('对折次数:', count)
    
  10. 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

    month = int(input('请输入月数:'))
    pre1 = 1
    pre2 = 1
    for num in range(2, month):
        pre1, pre2 = pre2, pre2+pre1
    print('兔子总数是:', pre2, '对')
    
  11. 将一个正整数分解质因数。例如:输入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
    
  12. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上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)
    
  13. 将一个正整数分解质因数。例如:输入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
    
  14. 本金10000元存入银行,年利率是千分之三。每过1年,将本金和利息相加作为新的本金。计算5年后,获得的本金是多少。

    principal = 10000
    interest_rate = 3 / 1000
    for x in range(5):
        principal += principal*interest_rate
    print('本金是:', principal)
    
  15. 输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)

    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)
    
  16. 求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)

    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)
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值