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, '次')
- 古典问题:有一对兔子,从出生后第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, '只')
- 将一个正整数分解质因数。例如:输入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')
- 输入两个正整数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))
- 一个数如果恰好等于它的因子之和,这个数就称为 "完数 "。例如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时需考虑多加一天。
-
某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值
-
获取第n个丑数。 什么是丑数: 因子只包含2,3,5的数
6 =1* 2*3 -> 丑数
2 = 1*2 -> 丑数
7 = 1*7 -> 不是丑数
1, 2, 3, 4, 5, 6, 8,9,10, 12 ….
网友评论