美文网首页
Day5-作业

Day5-作业

作者: 略略略_29fd | 来源:发表于2019-07-29 00:14 被阅读0次

    1.已知一个数字列表,求列表中心元素。

    list1 = [1, 2, 3, 4, 5, 6, 7, 8]
    n = len(list1)
    if n & 1:
        print('list1的中心元素是:', list1[n//2])
    else:
        print('list1的中心元素是:', list1[n//2-1], list1[n//2])
    
    

    2.已知一个数字列表,求所有元素和。

    list1 = [1, 2, 3, 4, 5]
    print(sum(list1))
    

    3.已知一个数字列表,输出所有奇数下标元素。

    list1 = [1, 2, 3, 4, 5, 6, 7, 8]
    for i in range(len(list1)):
        if i & 1:
            print(list1[i], end='\t')
    

    4.已知一个数字列表,输出所有元素中,值为奇数的元素。

    list1 = [1, 2, 3, 4, 5, 6, 7, 8]
    for n in range(len(list1)):
        if list1[n] & 1:
            print(list1[n], end = '\t')
    

    5.已知一个数字列表,将所有元素乘二。

    例如:nums = [1, 2, 3, 4] —> nums = [2, 4, 6, 8]

    list1 = [1, 2, 3, 4]
    for n in range(len(list1)):
        list1[n] *= 2
    print(list1)
    
    

    6.有一个长度是10的列表,数组内有10个人名,要求去掉重复的
    例如:names = ['张三', '李四', '大黄', '张三'] -> names = ['张三', '李四', '大黄']

    names = ['张三', '李四', '王二', '赵五', '张三', '小红', 
             '小明', '小红', '张三', '小小']
    i = 0
    count = 0
    while i < len(names)-count:
        j = i + 1
        while j < len(names):
            if names[i] == names[j]:
                names.pop(j)
                count += 1
                continue
            j += 1
        i += 1
    print(names)
    

    7.已经一个数字列表(数字大小在0~6535之间), 将列表转换成数字对应的字符列表
    例如: list1 = [97, 98, 99] -> list1 = ['a', 'b', 'c']

    list1 = [97, 98, 99, 5000, 1231]
    for n in range(len(list1)):
        list1[n] = chr(list1[n])
    print(list1)
    

    8.用一个列表来保存一个节目的所有分数,求平均分数(去掉一个最高分,去掉一个最低分,求最后得分)

    list1 = [70, 34, 15, 79, 97, 68, 89]
    list1.remove(max(list1))
    list1.remove(min(list1))
    ave = sum(list1) / len(list1)
    print('平均分是:', ave)
    

    9.有两个列表A和B,使用列表C来获取两个列表中公共的元素
    例如: A = [1, 'a', 4, 90] B = ['a', 8, 'j', 1] --> C = [1, 'a']

    list1 = [1, 2, 4, 5, 6, 9, 6, 9]
    list2 = [1, 4, 6, 7, 6, 8, 9, 1, 4, 6, 9]
    list3 = []
    for i in range(len(list1)):
        for j in range(len(list2)):
            if list1[i] == list2[j]:
                list3.append(list1[i])
                break
    a = 0
    count = 0
    while a < len(list3) - count:
        b = a + 1
        while b < len(list3):
            if list3[a] == list3[b]:
                list3.pop(b)
                count += 1
                continue
            b += 1
        a += 1
    print(list3)
    

    10.有一个数字列表,获取这个列表中的最大值.(注意: 不能使用max函数)

    例如: nums = [19, 89, 90, 600, 1] —> 600

    11.获取列表中出现次数最多的元素

    例如:nums = [1, 2, 3,1,4,2,1,3,7,3,3] —> 打印:3
    12.一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?

    h = 0.00008
    sum1 = 0
    while True:
        if h < 8848.13:
            h = h*2
            sum1 += 1
        else:
            break
    print('对折:', sum1, '次')
    
    1. 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
    f1 = 1
    f2 = 1
    n = int(input('请输入第几个月:'))
    f3 = 1
    for x in range(n-2):
        f3 = f1 + f2
        f2 = f1
        f1 =f3
    print('这个月的兔子有:', f3, '只')
    
    1. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。
    n = num = int(input('请输入数字:'))
    list1 = []
    for _ in range(n):
        for i in range(2, n + 1):
            if n % i == 0:
                list1.append(i)
                n = n // i
                break
    if len(list1) == 0:
        print('这个数字没有质素')
    else:
        print(num, '=', end="\t")
        for i in range(len(list1)):
            print('*%d'% list1[i], end='\t')
    
    1. 输入两个正整数m和n,求其最大公约数和最小公倍数。 程序分析:利用辗除法。
    m = int(input('请输入数字M:'))
    n = int(input('请输入数字N:'))
    num = m * n
    while n != 0:
        p = m%n
        m = n
        n = p
    print('最大公约数为:',m)
    print('最小公倍数为:',int(num/m))
    
    1. 一个数如果恰好等于它的因子之和,这个数就称为 "完数 "。例如6=1+2+3. 编程 找出1000以内的所有完数
    number = int(input("请输入要求的数以内有哪些完数:"))
    print(number, '以内的完数有:', end='')
    for y in range(2, number):
        list1 = []
        for i in range(1, y):
            if y % i == 0:
                list1.append(i)
    
        if sum(list1) == y:
            print(sum(list1), end=' ')
    

    17.输入某年某月某日,判断这一天是这一年的第几天? 程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于3时需考虑多加一天。

    1. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值

    2. 获取第n个丑数。 什么是丑数: 因子只包含2,3,5的数

    6 =1* 2*3 -> 丑数

    2 = 1*2 -> 丑数

    7 = 1*7 -> 不是丑数

    1, 2, 3, 4, 5, 6, 8,9,10, 12 ….

    相关文章

      网友评论

          本文标题:Day5-作业

          本文链接:https://www.haomeiwen.com/subject/mswdrctx.html