练习 : 数据类型之列表
1.已知一个数字列表,求列表中心元素。
list1 = [1, 3, 70, 9, 37, 5]
length1 = int(len(list1))
if length1 & 1 == 1:
print('中心元素为:',list1[int((length1 - 1) / 2)])
else:
print('中心元素为:',list1[int(length1 / 2 -1)],list1[int(length1 / 2)])
2.已知一个数字列表,求所有元素和。
list1 = [1, 3, 70, 9, 37, 5]
sum1 = 0
for num in list1:
sum1 += num
print(sum1)
3.已知一个数字列表,输出所有奇数下标元素。
list1 = [1, 3, 70, 9, 37, 5]
length1 = int(len(list1))
for ind1 in range(length1):
if ind1 & 1 == 1:
print(list1[ind1])
4.已知一个数字列表,输出所有元素中,值为奇数的元素。
list1 = [1, 3, 70, 9, 37, 5]
for num in list1:
if num & 1 == 1:
print(num)
5.已知一个数字列表,将所有元素乘二。
list1 = [1, 3, 70, 9, 37, 5]
ind1 = 0
for num1 in list1:
list1[ind1] = num1 * 2
ind1 += 1
print(list1)
6.有一个长度是10的列表,数组内有10个人名,要求去掉重复的
list1 = ['马六','张三','马六','马六', '李四', '大黄', '张三', '王二', '李四', '王二']
list2 = []
for name1 in list1:
if name1 not in list2:
list2.append(name1)
print(list2)
7.已经一个数字列表(数字大小在0~6535之间), 将列表转换成数字对应的字符列表
from random import randint
list1 = [randint(0,6535), randint(0,6535), randint(0,6535)]
list2 = list1[:]
ind1 = 0
for num1 in list1:
list2[ind1] = str(chr(num1))
ind1 += 1
print(list2)
8.用一个列表来保存一个节目的所有分数,求平均分数(去掉一个最高分,去掉一个最低分,求最后得分)
from random import randint
list1 = [randint(0,100),randint(0,100),randint(0,100),randint(0,100),randint(0,100)]
sum1 = 0
max1 = list1[0]
min1 = list1[0]
for num in list1:
# 求和
sum1 += num
# 求最大值
if num > max1:
max1 = num
# 求最小值
if num < min1:
min1 = num
print((sum1-max1-min1)/(len(list1)-2))
9.有两个列表A和B,使用列表C来获取两个列表中公共的元素
10.有一个数字列表,获取这个列表中的最大值.(注意: 不能使用max函数)
nums = [19, 89, 90, 600, 1]
max1 = 0
for x in nums:
if max1 <= x:
max1 = x
print(max1)
11.获取列表中出现次数最多的元素
1.一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?
n = 0
sum1 = 0
while True:
pro = (2 ** n) * 0.08
n += 1
sum1 += pro
if sum1 >= 8848130:
break
print(n)
2. 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
n = int(input('请输入月份:'))
p1 = 1
p2 = 1
if n == 1 or n == 2:
print('兔子当月的数量是:',1)
else:
for _ in range(n - 3):
p1 , p2 = p2 , p1 + p2
print('兔子当月的数量是:', p1 + p2)
3. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。
4. 输入两个正整数m和n,求其最大公约数和最小公倍数。 程序分析:利用辗除法。
5. 一个数如果恰好等于它的因子之和,这个数就称为 "完数 "。例如6=1+2+3. 编程 找出1000以内的所有完数
6.输入某年某月某日,判断这一天是这一年的第几天? 程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于3时需考虑多加一天。
7. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值
8. 获取第n个丑数。 什么是丑数: 因子只包含2,3,5的数