7.17周末作业-循环练习题

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

    count = 1
    for x in range(101, 200):
        for y in range(2, int(x ** 0.5) + 1):
            if x % y == 0:
                break
        else:
            count += 1
            print(x)
    print('101-200之间有', count,'个素数。')
    
  2. 求整数1~100的累加值,但要求跳过所有个位为3的数。

    sum1 = 0
    for x in range(1, 101):
        if x % 10 == 3:
            continue
        sum1 += x
    print('整数1~100跳过所有个位为3的数的累加值为:', sum1)
    
  3. 有⼀分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的第20个分数

    n = 20    # 这个数列第n个分数
    a1 = 1
    a2 = 1
    for x in range(n):
        a1, a2 = a2, a1 + a2
    print('这个数列第', n, '个分数的值:', a2, '/', a1)
    
  4. 写程序计算 n 的阶乘 n! 的结果

    num1 = 1
    n = int(input('请输入n:'))
    for x in range(1, n + 1):
        num1 *= x
    print(num1)
    
  5. 求1+2!+3!+…+20!的和

    sum1 = 0
    num1 = 1
    for x in range(1, 21):
        num1 *= x
        sum1 += num1
    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:'))
    n = int(input('请输入n:'))
    a_degeshu = 0
    n_dexiang = 0
    for y in range(n):
        a_degeshu += a
        a = a * 10
        n_dexiang += a_degeshu
    print(n_dexiang)
    
  7. 控制台输出三角形

    a.根据n的值的不同,输出相应的形状
    n = 5时             n = 4
    *****               ****
    ****                ***
    ***                 **
    **                  *
    *
    
    
    line = int(input("输入行数n: "))
    for x in range(0, line):
        print("*" * (line - x))
    
    b.根据n的值的不同,输出相应的形状(n为奇数)
    n = 5               n = 7
      *                    *
     ***                  ***
    *****                *****
                        *******
    
    line = int(input("输入n: "))
    for x in range(1, line + 2):
       if x % 2 == 1:
            print((" " * (4-int((x+1) / 2)))+ ("*" * x))
    
    c. 根据n的值的不同,输出相应的形状
    n = 4
       1
      121
     12321
    1234321
    
    n = 5
        1
       121
      12321
     1234321
    123454321
    
    # 1^2=1
    # 11^2=121
    # 111^2=12321
    # 1111^2=1234321
    
    line = int(input("输入n: "))
    num1 = 1
    for x in range(1,line+1):
        num1 = int(x * '1')
        num1 *= num1
        print(' '*(line-x),num1)
    
  8. 小明单位发了100元的购物卡,小明到超市买三类洗化用品,洗发水(15元),香皂(2元),牙刷(5元)。要把100元正好花掉,可有哪些购买结合?

    for x in range(51):  # 只买香皂最多买50个
        for y in range(21):
            for z in range(7):
                if x*2+y*5+z*15 == 100:
                    print(x, y, z)
    
  9. 一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?

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

    n = int(input('第几个月的兔子数量:'))
    if n < 4:
        print('第',n, '个月的兔子数量为:2')
    sum1 = 2
    sum2 = 2
    if n >= 4:
        for x in range(0, n-4):
            sum1, sum2 = sum2, sum1 + sum2
    print(sum1+sum2)
    
  11. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。

    n = int(input('请输入一个正整数:'))
    while n > 1:
        for y in range(2,n + 1):
            if n % y == 0:
                n = int(n / y)
                if n == 1:
                    print(y, end='')
                else:
                    print(y, 'x ',end='')
                break
    
  12. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值

    n = int(input('四位整数:'))
    n = ((n // 1000 + 5) % 10) + ((n //100 % 10 + 5) % 10) * 10 + ((n // 10 % 10 + 5) % 10) * 100 + ((n % 10 + 5) % 10) * 1000
    print(n)
    
  13. 同11题题目相同

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

    money = 10000
    rate = 0.003
    for x in range(5):
        money = money + money * rate
    print(money)
    
  15. 输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)

    n = int(input('输入一个整数'))
    num1 = 0
    while True:
        num1 += n % 10
        n = n // 10
        if n == 0:
            break
    print(num1)
    
  16. 求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)

    a = int(input('输入数字1:'))
    b = int(input('输入数字2:'))
    m, n = 0, 0
    c = 0
    if a >= b:
        m = b
    else:
        m = a
    for x in range(1, m+1):
        if a % x == 0 and b % x == 0:
            if x > n:
                n = x
    print(a,'和', b,'的最大公约数是:',n)
    c = int(a / n * b)
    print(a,'和', b,'的最小公倍数是:',c)
    
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这道题目需要我们实现一个循环链表,并在其中删除指定位置的节点。具体实现可以分为以下几个步骤: 1. 定义循环链表的节点结构体,包括数据域和指向下一个节点的指针域。 2. 定义循环链表的头节点,并初始化为空。 3. 读入输入的数据,将其插入到循环链表的尾部。 4. 遍历循环链表,找到需要删除的节点的前一个节点。 5. 将需要删除的节点从链表中摘除,并释放其内存空间。 6. 遍历循环链表,输出剩余节点的数据。 下面是具体的代码实现: ``` #include <iostream> using namespace std; // 定义循环链表的节点结构体 struct ListNode { int val; ListNode* next; ListNode(int x) : val(x), next(NULL) {} }; int main() { // 定义循环链表的头节点 ListNode* head = NULL; // 读入输入的数据,将其插入到循环链表的尾部 int num; while (cin >> num && num != 0) { ListNode* node = new ListNode(num); if (head == NULL) { head = node; head->next = head; } else { ListNode* cur = head; while (cur->next != head) { cur = cur->next; } cur->next = node; node->next = head; } } // 遍历循环链表,找到需要删除的节点的前一个节点 ListNode* pre = head; while (pre->next != head) { pre = pre->next; } // 将需要删除的节点从链表中摘除,并释放其内存空间 ListNode* cur = head; while (cur->next != head) { if (cur->val % 2 == 0) { pre->next = cur->next; ListNode* temp = cur; cur = cur->next; delete temp; } else { pre = cur; cur = cur->next; } } if (cur->val % 2 == 0) { pre->next = cur->next; delete cur; } // 遍历循环链表,输出剩余节点的数据 cur = head; while (cur->next != head) { cout << cur->val << "\t"; cur = cur->next; } cout << cur->val << endl; return 0; } --相关问题--:

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值