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

  1. 判断101-200之间有多少个素数,并输出所有素数。

    count = 0
    su = []
    for i in range(101, 200):
        su.append(i)
        for j in range(2, i):
            if i % j == 0:
                su.remove(i)
                break
        else:
            count += 1
    print('素数一共有', count, '个')
    print(su)
    
    # 素数一共有 21 个
    # [101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199]
    
    
    
  2. 求整数1~100的累加值,但要求跳过所有个位为3的数。

    sum = 0
    for i in range(1, 100):
        if i % 10 == 3:
            sum += 0
        else:
            sum += i
    print(sum)
    
    # 4470
    
  3. 有⼀分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的第20个分数

    fz1 = 2
    fz2 = 3
    fm1 = 1
    fm2 = 2
    for i in range(2, 20):
        n = fz1 + fz2
        m = fm1 + fm2
        fz1 = fz2
        fm1 = fm2
        fz2 = n
        fm2 = m
    print(fz2, '/', fm2)
    # 17711 / 10946
    
  4. 写程序计算 n 的阶乘 n! 的结果

    n = int(input('请输入一个正整数:'))
    result = 1
    for i in range(1,n+1):
        result *= i
    print(result)
    
  5. 求1+2!+3!+…+20!的和

    sum = 0
    for i in range(1, 21):
        result = 1
        for j in range(1, i+1):
            result *= j
        sum += result
    print(sum)
    # 2561327494111820313
    
  6. 写程序求表达式 a + aa + aaa + aaaa+ … 的结果,其中a是1~9的数字,求和的项数用n来控制。(a和n可以用变量来表示)

    例如:a为3, n为5的时候: 3 + 33 + 333 + 3333 + 33333

    a = b = 3
    n = 5
    s = 0
    for i in range(n-1):
        s += a
        a = a*10 + b
    print(s)
    # 3702
    
  7. 控制台输出三角形

    a. 根据n的值的不同,输出相印的形状
    n = 5
    *****
    ****
    ***
    **
    *
    
    n = 5
    for i in range(n, 0, -1):
        print('*'*(i))
        
    
    
    b.根据n的值的不同,输出相应的形状(n为奇数)
    n = 5               n = 7
      *                    *
     ***                  ***
    *****                *****
                        *******
    n = int(input('请输入一个奇数:'))
    for i in range(1, n+1, 2):
        m = int((n-i)/2)
        print(' ' * m, '*' * i, ' ' * m)    
     
    
    c. 根据n的值的不同,输出相应的形状
    n = 4
       1
      121
     12321
    1234321
    
    n = 5
        1
       121
      12321
     1234321
    123454321
    
    
    n = int(input('请输入一个数:'))
    num = 1
    count = 0
    list = [1]
    # 获取第n个奇数
    while count < n-1:
        num += 2
        count += 1
        list.append(num)
    print(num)
    print(list)
    
    # 输出数字三角形
    for i in range(n):
        s = ''
        s += str(i+1)
        l = i+1
        while l != 1:
            s = s + str(l-1)
            s = str(l-1) + s
            l -= 1
            # print(s)
        for j in range(1, num+1, 2):
            blank = int((num-list[i])/2)
        print(' ' * blank, s, ' ' * blank)
    
    
  8. 小明单位发了100元的购物卡,小明到超市买三类洗化用品,洗发水(15元),香皂(2元),牙刷(5元)。要把100元正好花掉,可有哪些购买结合?

    for i in range(100//15):
        for j in range(50):
            for k in range(20):
                if 15*i + 2*j +5*k == 100:
                    print('洗发水:',i,'香皂:', j, '牙刷', k)
              
    """
    洗发水: 0 香皂: 5 牙刷 18
    洗发水: 0 香皂: 10 牙刷 16
    洗发水: 0 香皂: 15 牙刷 14
    洗发水: 0 香皂: 20 牙刷 12
    洗发水: 0 香皂: 25 牙刷 10
    洗发水: 0 香皂: 30 牙刷 8
    洗发水: 0 香皂: 35 牙刷 6
    洗发水: 0 香皂: 40 牙刷 4
    洗发水: 0 香皂: 45 牙刷 2
    洗发水: 1 香皂: 0 牙刷 17
    洗发水: 1 香皂: 5 牙刷 15
    洗发水: 1 香皂: 10 牙刷 13
    洗发水: 1 香皂: 15 牙刷 11
    洗发水: 1 香皂: 20 牙刷 9
    洗发水: 1 香皂: 25 牙刷 7
    洗发水: 1 香皂: 30 牙刷 5
    洗发水: 1 香皂: 35 牙刷 3
    洗发水: 1 香皂: 40 牙刷 1
    洗发水: 2 香皂: 0 牙刷 14
    洗发水: 2 香皂: 5 牙刷 12
    洗发水: 2 香皂: 10 牙刷 10
    洗发水: 2 香皂: 15 牙刷 8
    洗发水: 2 香皂: 20 牙刷 6
    洗发水: 2 香皂: 25 牙刷 4
    洗发水: 2 香皂: 30 牙刷 2
    洗发水: 2 香皂: 35 牙刷 0
    洗发水: 3 香皂: 0 牙刷 11
    洗发水: 3 香皂: 5 牙刷 9
    洗发水: 3 香皂: 10 牙刷 7
    洗发水: 3 香皂: 15 牙刷 5
    洗发水: 3 香皂: 20 牙刷 3
    洗发水: 3 香皂: 25 牙刷 1
    洗发水: 4 香皂: 0 牙刷 8
    洗发水: 4 香皂: 5 牙刷 6
    洗发水: 4 香皂: 10 牙刷 4
    洗发水: 4 香皂: 15 牙刷 2
    洗发水: 4 香皂: 20 牙刷 0
    洗发水: 5 香皂: 0 牙刷 5
    洗发水: 5 香皂: 5 牙刷 3
    洗发水: 5 香皂: 10 牙刷 1
    """
    
  9. 一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?

    # 将毫米换算为米
    h = 0.08 * 10 ** -3
    
    count = 0
    while h < 8848.13:
        h *= 2
        count += 1
    print(count)
    # 27
    
  10. 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

    n = int(input('到第几个月:'))
    m1 = 1  # 第一个月有一对兔子
    m2 = 1  # 第二个月有一对兔子
    data1 = {'1': m1, '2': m2}  # 存放每个月的兔子对数
    for i in range(3, n+1):
    	data1[str(i)] = data1[str(i-1)] + data1[str(i-2)]
    print(data1)
    

{‘1’: 1, ‘2’: 1, ‘3’: 2, ‘4’: 3, ‘5’: 5, ‘6’: 8, ‘7’: 13, ‘8’: 21, ‘9’: 34, ‘10’: 55, ‘11’: 89, ‘12’: 144, ‘13’: 233, ‘14’: 377, ‘15’: 610, ‘16’: 987, ‘17’: 1597, ‘18’: 2584, ‘19’: 4181, ‘20’: 6765, ‘21’: 10946, ‘22’: 17711, ‘23’: 28657, ‘24’: 46368, ‘25’: 75025, ‘26’: 121393, ‘27’: 196418, ‘28’: 317811, ‘29’: 514229, ‘30’: 832040}
11. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。

```python
# 获取因数
n = int(input('请输入整数:'))
list = []
num = 1
while n > 1:
    n = n // num
    for i in range(2, n+1):
        if n % i != 0:
            continue
        else:
            for j in range(2, i//2):
                if i % j == 0:
                    break
            else:
                list.append(i)
                num = i
                break
print(list)

# 输出数学式:
print(90, '=', end='')
for i in list[0:-2]:
    print(i, end='x')
print(list[-1])
```
  1. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值

    pwd = input('请输入传递数据:')
    s = '' # 中间变量
    pwd_1 =''  # 存放加密后数据
    for i in pwd:
        s += str((int(i)+5) % 10)
    pwd_1 = s[3]+s[2]+s[1]+s[0]
    print(pwd_1)
    
  2. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。

  3. 本金10000元存入银行,年利率是千分之三。每过1年,将本金和利息相加作为新的本金。计算5年后,获得的本金是多少。

    ben = 10000  # 本金
    r = 3**10*(-3)  # 年利率
    for i in range(4):
        ben= ben*(1+r)
    print(ben)
    
    # 9847486661296306598560000
    
  4. 输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)

    n = input('请输入一个任意位数的整数:')
    num = int(n)
    sum =0 
    # 如果是负数,需要去掉负号
    if num < 0:
        n = n[1:]
    n=list(n)
    for i in n:
        sum += int(i)
    print(sum)
    
  5. 求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)

    m = int(input('请输入一位整数'))
    n = int(input('请输入另一位整数'))
    m, n = max(m, n), min(m, n)
    
    gy = 1 # 存放最大公约数
    gb = m*n # 存放最小公倍数
    
    for i in range(1, n+1):
        if m % i != 0 or n % i != 0:
            continue
        elif i > gy:
            gy = i
    print('最大公约数', gy)
    
    for i in range(m, m*n+1):
        if i % m != 0 or i % n != 0:
            continue
        elif i < gb:
            gb = i
    print('最小公倍数', gb)
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值