周末作业-循环练习题

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

    s = 0
    for i in range(0, 101):
        if i % 10 == 3:
            s = s
        else:
            s += i
    print(s)
    
  3. 有⼀分数序列: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)
    
  4. 写程序计算 n 的阶乘 n! 的结果

    n = int(input('输入正整数n'))
    s = 1
    for i in range(1, n+1):
        s *= i
    print(n, '!', '的结果为', s)
    
  5. 求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)
    
  6. 写程序求表达式 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)
    
  7. 控制台输出三角形

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

    thk = 0.08 * 10 ** (-3)
    i = 2
    count = 0
    while thk < 8848.13:
        thk *= i
        count += 1
    print('需要对折', count, '次')
    
  10. 古典问题:有一对兔子,从出生后第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, '只')
    
  11. 将一个正整数分解质因数。例如:输入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
    
  12. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上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='')
    
  13. 本金10000元存入银行,年利率是千分之三。每过1年,将本金和利息相加作为新的本金。计算5年后,获得的本金是多少。

    i = 0
    x = 10000
    while i < 5:
        p = x * 0.003
        x += p
        i += 1
    print('五年后,新的本金为:', x, '元')
    
  14. 输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)

    num = int(input('输入任意整数'))
    s = 0
    while num % 10 != 0:
        s += num % 10
        num = num // 10
    print('该整数各位上数字的和为:', s)
    
  15. 求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值