2022年4月18号第二周第一天作业

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

nums = [10, 20, 30, 40, 50, 60]
if len(nums) % 2 == 0:
    print(nums[int(len(nums)/2) - 1], nums[int(len(nums)/2)])
else:
    print(nums[int(len(nums)/2)])

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

total = 0
nums = [10, 20, 30, 40, 50, 60]
for i in nums:
    total += i
print(total)

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

nums = [10, 20, 30, 40, 50, 60]
for i in range(len(nums)):
    if i % 2:
        print(nums[i])

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

nums = [11, 12, 13, 14, 15, 16, 17]
for i in nums:
    if i % 2:
        print(i)

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

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

nums = [1, 2, 3, 4]
list1 = []
for i in nums:
    list1.append(i * 2)
print(list1)

6.有一个长度是10的列表,数组内有10个人名,要求去掉重复的

例如:names = [‘张三’, ‘李四’, ‘大黄’, ‘大黄’, ‘张三’, ‘张三’, ‘张三’] -> names = [‘张三’, ‘李四’, ‘大黄’]

names = ['张三', '李四', '大黄', '大黄', '张三', '张三', '张三']
list1 = []
for i in names:
    if i not in list1:
        list1.append(i)
print(list1)

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

nums = [10, 22, 54, 84, 42, 34, 5, 67]
nums.remove(max(nums))
nums.remove(min(nums))
total = 0
for i in nums:
    total += i
print(total/len(nums))

8.有两个列表A和B,使用列表C来获取两个列表中公共的元素

例如: A = [1, ‘a’, 4, 90] B = [‘a’, 8, ‘j’, 1] --> C = [1, ‘a’]

listA = [1, 'a', 4, 90]
listB = ['a', 8, 'j', 1]
listC = []

for i in listA:
    if i in listB:
        listC.append(i)
print(listC)

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

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

# 冒泡排序
nums = [19, 89, 90, 600, 1]
for i in range(1, len(nums)):
    for j in range(len(nums)):
        if nums[j] > nums[i]:
            nums[j], nums[i] = nums[i], nums[j]
print(nums[-1])

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

例如:nums = [1, 2, 3,1,4,2,1,3,7,3,3] —> 打印:3

nums = [1, 2, 3, 1, 4, 2, 1, 3, 7, 3, 3]
list1 = []
list2 = []
max1 = 0
for i in nums:  # 去掉重复的元素
    if i not in list1:  # 去掉重复的元素
        list1.append(i)  # 去掉重复的元素
for i in list1:  # 遍历每个元素
    if nums.count(i) > max1:  # 假如num里面的元素的个数大于max1
        max1 = nums.count(i)  # 把nums.count(i)赋值给max1
        list2.clear()  # 清空list2防止重复添加相同的元素
        list2.append(i)  # 像空列表内添加重复元素最多的元素
    elif nums.count == max1:  # 如果有2个元素个数是相同的话
        list2.append(i)  # 那么往列表里面添加这个元素
print(list2)  # 最后打印list2
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是C语言代码: ```c #include <stdio.h> int main() { int n; scanf("%d", &n); if (n > 31) { n -= 31; } int days = (n - 1) * 7 + 3; int year = 2022 + days / 366; int remain_days = days % 366; int month, day; if (remain_days < 31) { month = 1; day = remain_days + 1; } else if (remain_days < 59) { month = 2; day = remain_days - 30; } else if (remain_days < 90) { month = 3; day = remain_days - 58; } else if (remain_days < 120) { month = 4; day = remain_days - 89; } else if (remain_days < 151) { month = 5; day = remain_days - 119; } else if (remain_days < 181) { month = 6; day = remain_days - 150; } else if (remain_days < 212) { month = 7; day = remain_days - 180; } else if (remain_days < 243) { month = 8; day = remain_days - 211; } else if (remain_days < 273) { month = 9; day = remain_days - 242; } else if (remain_days < 304) { month = 10; day = remain_days - 272; } else if (remain_days < 334) { month = 11; day = remain_days - 303; } else { month = 12; day = remain_days - 333; } printf("%d%d%d日是", year, month, day); int day_of_week = (days + 5) % 7; switch (day_of_week) { case 0: printf("星期天"); break; case 1: printf("星期一"); break; case 2: printf("星期二"); break; case 3: printf("星期三"); break; case 4: printf("星期四"); break; case 5: printf("星期五"); break; case 6: printf("星期六"); break; } return 0; } ``` 当输入n时,程序会先判断n是否大于31,如果大于31,则将n减去31。 然后,程序会根据n算出对应的日期。首先,算出2022318日是当的第77天。每增加一个,就增加7天。假设当前份是2022,那么每的天数是366天(因为是闰)。所以,当超过366天时,需要将份加1,并把当前已经过的天数减去366。 通过算出对应的日期,接下来再计算对应是星期几。由于已知2022318日是星期五,所以可以按照一周七天推算出对应星期几。最后,输出对应的日期和星期几即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值