文档结构

  • 练习题


练习题

1、使用一行代码实现给定列表的奇偶数分离;list_a = [11, 22, 45,17,19,21,76,34,28,59]
答案:此处使用 列表推导式实现;

>>> 
>>> list_a = [11, 22, 45,17,19,21,76,34,28,59]
>>> part_js,part_os =[x for x in list_a if x%2==1],[x for x in list_a if x%2==0]
>>> part_js
[11, 45, 17, 19, 21, 59]
>>> part_os
[22, 76, 34, 28]
>>>

2、编写程序,输出给定范围序列内的所有质数;
答案:此处使用 lamda表达式,all()函数以及 filter 函数实现;

start_n = int(input("请输入序列起始值:"))
end_n = int(input("请输入序列终止值:"))
iter_rt = filter(lambda x: all(x % y != 0 for y in range(2, x)), range(start_n, end_n))
list_rt = list(iter_rt)
print(list_rt)

# 结果输出
请输入序列起始值:20
请输入序列终止值:70
[23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67]

Process finished with exit code 0

此处也可以使用常规的循环方式实现:

start_n = 20
stop_n = 70
list_rt = list()
for x in range(start_n, stop_n + 1):
    flag = True
    for y in range(2, x):
        if x % y == 0:
            flag = False
            break

    if flag:
        list_rt.append(x)

print(list_rt)

3、编写程序输出前10个斐波那契数列;
答案:此处使用列表推导式实现;

fibo = [0, 1]
[fibo.append(fibo[-2] + fibo[-1]) for i in range(0,8)]
print(fibo)

# 结果输出
[0, 1, 1, 2, 3, 5, 8, 13, 21, 34]

Process finished with exit code 0

扩展:该题也可以考虑使用递归函数来实现,参数支持2种类型,一种按照序列数来输入,一种按照阈值范围来确定;
实现:按照递归函数和参数名称来赋值;

# coding=utf-8

fibo = [0, 1]

def queryFibo(count=0, stop_n=0):
    if count:
        if len(fibo) < count:
            fibo.append(fibo[-2] + fibo[-1])
            return queryFibo(count=count)
        else:
            return fibo
    elif stop_n:
        if (fibo[-2] + fibo[-1]) <= stop_n:
            fibo.append(fibo[-2] + fibo[-1])
            return queryFibo(stop_n=stop_n)
        else:
            return fibo


queryFibo(count=11)
print(fibo)
queryFibo(stop_n=60)
print(fibo)

# 输出结果
[0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55]
[0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55]

Process finished with exit code 0

4、编写程序判断一个数字是否为阿姆斯特朗数(Armstrong),

说明:如果一个n位正整数等于其各位数字的n次方之和,则称该数为阿姆斯特朗数,如下所示:

将整数插入列表python python将整数变成列表_将整数插入列表python


扩展:此处可以编码实现输出前固定项的Armstrong 或者在某个范围内符合Armstrong特征的值;

A:定义函数selectArmstrong 实现 Armstrong 值的判断

def selectArmstrong(input_n: int) -> bool:
    len_n = len(str(input_n))
    split_n = [int(x) ** len_n for x in str(input_n)]
    sum_n = sum(split_n)
    return True if input_n == sum_n else False

说明:这里使用到了列表推导式、三元表达式、列表求和操作;

B:定义函数 getArmstrong 获取 Armstrong值;要不输入最大边界值,要不输入符合的数据项个数;

def getArmstrong(count=0, start_n=1, stop_n=1):
    if count >= 1 and len(list_rt) < count:
        if selectArmstrong(start_n):
            list_rt.append(start_n)
        return getArmstrong(start_n=start_n + 1, count=count)

    elif start_n <= stop_n:
        if selectArmstrong(start_n):
            list_rt.append(start_n)
        return getArmstrong(start_n=start_n + 1, stop_n=stop_n)

说明:此处使用递归函数计算符合特殊的数值;

C:定义结果列表和 输出逻辑:

list_rt = list()
getArmstrong(count=12)
print(list_rt)

# 输出结果
[1, 2, 3, 4, 5, 6, 7, 8, 9, 153, 370, 371]

Process finished with exit code 0

方法二:使用列表推导式实现,selectArmstrong函数公用;

list_rt = list()
start_n, stop_n = 11, 390
[list_rt.append(x) for x in range(start_n, stop_n) if selectArmstrong(x)]

print(list_rt)

# 结果输出
[153, 370, 371]

Process finished with exit code 0

5、编码实现一行代码展开列表 [[1,2],[3,4],[5,6]],得到新的列表 [1,2,3,4,5,6]?
答案:列表推导式实现:

>>> 
>>> list_1=[[1,2],[3,4],[5,6]]
>>> list_2=[j for i in list_1 for j in i]
>>> list_2 
[1, 2, 3, 4, 5, 6]
>>>

6、编码实现 str_a = “ajldjlajfdljfddd”,去重并从小到大排序输出"adfjl"?
答案:先将字符串转换为集合,在转换为列表,最好排序;

>>> str_a = "ajldjlajfdljfddd" 
>>> list_a=list(set(str_a))
>>> list_a.sort()
>>> str_b="".join(list_a)
>>> str_b

说明:list.sort() 函数没有返回值,所以不能直接将其赋值给另外一个变量;

7、编码实现 字典 dict_a={“name”:“zs”,“age”:18,“city”:“深圳”,“tel”:“1362626627”} 根据键从小到大排序?
方式A:取出键值,排序后赋值给新的字典;

>>> 
>>> dict_a={"name":"zs","age":18,"city":"深圳","tel":"1362626627"}
>>> dict_new={}
>>> list_a=list(dict.keys())
>>> list_a.sort(reverse=False)
>>> for x in list_b:
...     dict_new[x]=dict[x]
... 
>>> dict_new
{'age': 18, 'city': '深圳', 'name': 'zs', 'tel': '1362626627'}

方式B:使用内置函数排序生成新的列表

>>> dict_a={"name":"zs","age":18,"city":"深圳","tel":"1362626627"}
>>> dict_b={}
>>> list_b=sorted(dict_a.items(),key=lambda i:i[0],reverse=False)
>>> list_b
[('age', 18), ('city', '深圳'), ('name', 'zs'), ('tel', '1362626627')]
>>> 
>>> for y in list_b:
...     dict_b[y[0]]=y[0]
... 
>>> 
>>> dict_b
{'age': 18, 'city': '深圳', 'name': 'zs', 'tel': '1362626627'}
>>>

8、编码 list=[2,3,5,4,9,6],从小到大排序,不许用sort,输出[2,3,4,5,6,9]?
实现逻辑:递归将原列表最小值赋值给新列表;

list_aa=[22,11,33,55,22,77,99,88]
list_ll=[]

def sortList(var:list):

    if len(var)>0:
        min_n=min(var)
        list_ll.append(min_n)
        var.remove(min_n)
        sortList(var)

    return list_ll

print(sortList(list_aa))

9、代码举例说明如何交换两个数值?
代码实现:

>>> 
>>> num_1,num_2=11,22
>>> print(num_1,num_2)
11 22
>>> num_1,num_2=num_2,num_1
>>> print(num_1,num_2)
22 11
>>>

10、代码举例说明如何实现列表去重?
实现方式:先转为集合,再转为列表,代码如下:

>>> list_a=["aaa","bbb","aaa",11,22,33,33]
>>> set_a=set(list_a)
>>> print(set_a)
{33, 11, 22, 'aaa', 'bbb'}
>>> list_b=list(set_a)
>>> print(list_b)
[33, 11, 22, 'aaa', 'bbb']

11、字符串a = “not 404 found 张三 99 深圳”,每个词中间是空格,用正则过滤掉英文和数字,最终输出"张三 深圳"?

在这里插入代码片

12、x=“abc”,y=“def”,z=[“d”,“e”,“f”],分别求出x.join(y)和x.join(z)返回的结果?
代码实现:

在这里插入代码片

13、编码实现 n 的阶乘;
实现A:循环方式

def getfactor(stop_n):
    curr_v = 1
    for x in range(1, stop_n + 1):
        curr_v *= x
    return curr_v

实现B:递归方式
说明:递归方式有递归深度限制;

def getfactor(stop_n):
    if stop_n == 1:
        return 1
    elif stop_n > 1:
        return stop_n * getfactor(stop_n=stop_n - 1)

14、编码实现 1! + 2!+ 3! + …n! 之和;
实现A:递归计算,此处复用阶乘函数 getfactor;

def sumfactor(stop_n):
    if stop_n == 1:
        return 1
    elif stop_n > 1:
        return getfactor(stop_n) + sumfactor(stop_n - 1)

实现B:循环实现

def sumfactor(stop_n: int):
    sum_v, curr_v = 0, 1
    if stop_n == 1:
        sum_v = 1
    elif stop_n > 1:
        for x in range(1, stop_n + 1):
            curr_v *= x
            sum_v += curr_v

    return sum_v

说明:这种实现方式代码简单,而且就有些优雅了;

15、编码计算2个数的最大公约数和最小公共倍数;
答案;

在这里插入代码片

16、编写函数判断输入的年份是否为闰年;
说明:闰年的判断规则为 非100倍数的年份,可以被4整除;100倍数的年份可以被400整除;

def selectLeapYear(year_v: int):
    if (year_v % 4 == 0 and year_v % 100 != 0) or (year_v % 400 == 0):
        return True
    else:
        return False

17、编码实现键盘输入的值进行因式分解,如 120 = 2* 2* 235 ;
分析:进行分解时,当除数 大于 被除数的一半时无需再进行分解;

t = 120
i = 2
list_rt = list()
while True:
    if i >= (t / 2):
        list_rt.append(t)
        break
    if t % i == 0:
        list_rt.append(i)
        t /= i
    else:
        i += 1

    print(f"t={t},i={i}")

print(list_rt)

18、编码求解:假设有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
分析:列出每个月的兔子数值,发现类似于斐波那契数列,1,1,2,3,5,8,13,21…

list_rt = [1, 1]

def getfibo(month_n: int):
    if month_n <= 2:
        return list_rt[month_n - 1]
    elif len(list_rt) >= month_n:
        return list_rt[-1]
    else:
        list_rt.append(list_rt[-2] + list_rt[-1])
        return getfibo(month_n)

19、编码计算一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在
第10次落地时,共经过多少米?第10次反弹多高?
分析:

# coding=utf-8

def totalPath(level):
    sum_v = 100
    curr_l = 100

    if level == 1:
        return sum_v, curr_l / 2
    else:
        for x in range(2, level + 1):
            sum_v += curr_l
            curr_l /= 2

    return sum_v, curr_l/2


print(totalPath(4))