第1周作业(进阶题)

  1. 判断101-200之间有多少个素数,并输出所有素数。
count = 0
for i in range(101, 201):
    flag = True
    for x in range(2, i):
        if i % x == 0:
            flag = False
            break
    if flag:
        print(i)
        count += 1
print(count)
  1. 求整数1~100的累加值,但要求跳过所有个位为3的数。
sum = 0
for i in range(1, 101):
    if i % 10 != 3:
        sum += i
print(sum)
  1. 有⼀分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的第20个分数
fb = [1, 2]
for i in range(19):
    n = fb[-1] + fb[-2]
    fb.append(n)
num = fb[-1] / fb[-2]
print(num)
  1. 写程序计算 n 的阶乘 n! 的结果
result = 1
for i in range(1, n + 1):
    result *= i
print(result)
  1. 求1+2!+3!+…+20!的和
for a in range(1, 21):
    result = 1
    for i in range(1, a + 1):
        result *= i
    sum += result
print(sum)
  1. 写程序求表达式 a + aa + aaa + aaaa+ … 的结果,其中a是1~9的数字,求和的项数用n来控制。(a和n可以用变量来表示)

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

    sum = 0
    s = '1'
    for i in range(1, 1 + n):
        num = int(n * s) * a
        sum += num
    print(sum)
    
  2. 控制台输出三角形

    a.根据n的值的不同,输出相应的形状						   
                                               
    n = 5时             n = 4
    *****               ****
    ****                ***
    ***                 **
    **                  *
    *
    
    for i in range(5):
    print('*'*(n-i))
    
    b.根据n的值的不同,输出相应的形状(n为奇数)        
    n = 5               n = 7
      *                    *
     ***                  ***
    *****                *****
                        *******
    
    n = 5
    hang = (n + 1) / 2
    for i in range(int(hang)):
        star = 1 + 2 * i
        kong = int((n - star) / 2)
        print(' ' * kong + '*' * star)
    
    c. 根据n的值的不同,输出相应的形状
    n = 4
       1
      121
     12321
    1234321
    
    n = 5
        1
       121
      12321
     1234321
    123454321
    
    n = 5  # zongchang=2n-1
    for i in range(1, n + 1):
        list_left = list(range(1, i + 1))
        list_right = list(range(i - 1, 0, -1))
        str1 = ''
        for i in list_left:
            str1 += str(i)
        for i in list_right:
            str1 += str(i)
        nums_len = len(str1)
        kong = (2 * n - 1 - nums_len) / 2
        print(' ' * int(kong) + str1)
    
  3. 小明单位发了100元的购物卡,小明到超市买三类洗化用品,洗发水(15元),香皂(2元),牙刷(5元)。要把100元正好花掉,可有哪些购买结合?

for a in range(1, 7):
    for b in range(1, 51):
        for c in range(1, 21):
            if 15 * a + 2 * b + 5 * c == 100:
                print(a, b, c)
  1. 一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?
n = 1
while True:
    if 0.08 * 2 ** n > 8848130:
        print(n)
        break
    else:
        n += 1
  1. 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
one = 1
two = 0
three = 0
for i in range(n - 1):
    three = three + two
    two = one
    one = three
sum1 = (one + two + three) * 2
print(sum1)
  1. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。
while True:
    flag = True
    for i in range(2, n):
        if n % i == 0:
            print(i)
            list1.append(i)
            n = n // i
            flag = False
            break
    if flag:
        print(n)
        list1.append(n)
        break
  1. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值

    num = int(input('请输入4位数:'))  # 1234
    qian = num // 1000
    bai = num // 100 % 10
    shi = num // 10 % 10
    ge = num % 10
    
    qian1 = (qian + 5) % 10
    bai1 = (bai + 5) % 10
    shi1 = (shi + 5) % 10
    ge1 = (ge + 5) % 10
    
    qian1, ge1 = ge1, qian1
    bai1, shi1 = shi1, bai1
    
  2. 本金10000元存入银行,年利率是千分之三。每过1年,将本金和利息相加作为新的本金。计算5年后,获得的本金是多少。

print(10000 * (1 + 0.003) ** 5)
  1. 输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)
num = input('请输入一个整数:')
list1 = []
for i in num:
    list1.append(int(i))
all = sum(list1)
print(all)
  1. 求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)

num1 = int(input(‘请输入一个整数:’)) # 90
num2 = int(input(‘请输入另一个整数:’)) # 60
yinshu = 1
for i in range(min(num1, num2), 0, -1):
if num1 % i == 0 and num2 % i == 0:
yinshu = i
break
beishu = num1 * num2 // yinshu
print(‘最大公因数是:{},最小公倍数是:{}’.format(yinshu, beishu))





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值