python习题库132-142

2024-02-23 07:48
文章标签 python 习题 142 132

本文主要是介绍python习题库132-142,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

习题132、递归求两个数的最大公约数

方法1
算法
找出两个数的较小数(第一次)
如果两个数除以较小数余数都等于0的话,添加到一个列表中
不然的话继续调用函数自身,并且num-1传入到num参数中。

def max_common_divisor(a,b,num=0,result=[]):  if num == 0:if a < b:num = aelse:num = bif a%num == 0 and b%num == 0:print(result)result.append(num)else:max_common_divisor(a,b,num-1)return result
print(max_common_divisor(24,120))

在这里插入图片描述
方式2:更相减损法

def get(small,big):if small > big:small,big = big,smallif small == big:return smallreturn get(small,big-small)print(get(30,24))

在这里插入图片描述
方式3:辗转相除法

def gain(small,big):if small >big:small,big = big ,smallif small == 0:return bigreturn gain(small,big % small)
print(gain(24,30))

在这里插入图片描述

习题133、非递归实现求第n项斐波那契数列值

算法:遍历n,如果n等于0或1直接返回1
如果n >=2,记录前面两个项的和,并重新记录新的第1个,第2个数;

#coding=utf-8
def fib(n):a,b=1,1sum=0if n<=0 or not isinstance(n,int):return -1for i in range(n):if i <2:sum =1else:sum=a+ba=bb=sumreturn sumprint(fib(1))
print(fib(2))
print(fib(3))
print(fib(4))
print(fib(5))

在这里插入图片描述

习题134、利用递归,处理嵌套列表,生成列表[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]

知识点global语句的作用
在编写程序的时候,如果想为一个在函数外的变量重新赋值,并且这个变量会作用于许多函数中时,就需要告诉python这个变量的作用域是全局变量。此时用global语句就可以变成这个任务,也就是说没有用global语句的情况下,是不能修改全局变量的。
在python的函数使用时,经常会碰到参数定义的问题。如果不声明全局变量,用global声明多个变量需要用逗号分隔。

result=[]
def func(p):global resultfor v in p:if not isinstance(v,list):result.append(v)else:func(v)return result
l=[1,2,[3,4,[5,6,7,[8,9,[10,11]]]]]
print(func(l))

在这里插入图片描述

习题135、[1,2,3,4,5] 变成 [5,1,2,3,4]

方法1

a=[1,2,3,4,5]result = []
result.append(a[-1])
result.extend(a[0:4])
print(result)

在这里插入图片描述
方法2

result = []
result.append(a[-1])
for v in a[0:4]:result.append(v)
print(result)

在这里插入图片描述
方法3

a=[1,2,3,4,5]result = []for v in a[0:4]:result.append(v)result.insert(0,a[-1])
print(result)

在这里插入图片描述

习题136、统计字符串的个数

l = [1,2,"s",[1,23],{1:2},(1,2),set([1,2]),"b"]
str_number=0
for v in l:if isinstance(v,str):str_number+=1
print(str_number)

在这里插入图片描述

习题137、统计列表中所有类型数据的个数

l = [1,2,"s",[1,23],{1:2},(1,2),set([1,2]),"b"]
d={"str":0,"list":0,"tuple":0,"int":0,"set":0}for v in l:if isinstance(v,str):d["str"]+=1elif isinstance(v,list):d["list"]+=1elif isinstance(v,tuple):d["tuple"]+=1elif isinstance(v,int):d["int"]+=1elif isinstance(v,set):d["set"]+=1
print(d)

在这里插入图片描述

习题138、求列表中所有数字的和,包括数字字符串

a=[1,2,3,[4,5,6],{1:6,2:8,"a":"12",3:4}]
result=0
for value in a:if isinstance(value,int):result+=valueelif isinstance(value,list):for v in value:if isinstance(v,int):result+=velif isinstance(value,dict):for key in value.keys():if isinstance(key,int):result+=keyfor v in value.values():if isinstance(v,int):result+=velif v.isdigit():result+=int(v)
print(result)

在这里插入图片描述

习题139、将字符串:“k:1|k1:2|k2:3|k3:4”,处理成 python 字典:{‘k’:‘1’, ‘k1’:‘2’, ‘k2’:‘3’,‘k3’:‘4’ }

s="k:1|k1:2|k2:3|k3:4"
result_dict={}
s_list=s.split("|")for v in s_list:key=v.split(":")[0]value=v.split(":")[1]result_dict[key]=value
print(result_dict)

在这里插入图片描述

习题140、一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少? 程序分析:在10万以内判断

析:在10万以内判断
分析:
1 x 在10万里面,x是某个数,不知道是谁
2 (x+100)开方 = y y整数,
3 (x++100+168)开方 = z z 整数
4 开方:math.sqrt
5 怎么判断z 和y 是否整数?
y2是整数且是x++100
z
2是整数且是x++100+168

import math
result=[]
for i in range(100000):x=math.sqrt(i+100)y=math.sqrt(i+100+168)if (int(x)**2==i+100) and (int(y)**2==i+100+168):result.append(i)
print(result)

在这里插入图片描述

习题141、请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。

def get_week_day():s=["Monday","Tuesday","wednesday","Thursday","Friday","Saturday","Sunday"]result=[]first_letter=input("请输入第一个字母:")for day in s:if day[0]==first_letter.upper():result.append(day)if len(result)==0:print("输入的字母不正确")if len(result)==1:return result[0]if len(result)==2:second_letter=input("请输入第二个字母:")for day in s:if day[1]==second_letter.lower():return dayif __name__ == "__main__":print(get_week_day())

在这里插入图片描述

习题142、{‘k’: ‘1’, ‘k1’: ‘2’, ‘k2’: ‘3’, ‘k3’: ‘4’}拼回:“k:1|k1:2|k2:3|k3:4”

算法
字典的key取出来,然后用sort或者sorted均可
1 先把字典的key排序
2 然后按照排序后的key,依次取value,然后使用:,
把key和value做拼接,然后把拼接后的结果存到一个列表里面
3 使用join,使用|将列表的所有元素做拼接

方法1:
遍历字典的key,把key、”:”、value 拼接成字符串,然后加入列表,最后列表转换为字符串

d={"k":"1","k1":"2","k2":"3","k3":"4"}
result=[]
for key in sorted(d.keys()):s=key+":"+d[key]result.append(s)print(result)
print("|".join(result))

在这里插入图片描述
方法2
遍历字典的key、value把key\value加入一个临时列表,临时列表用”:”拼接成字符串,加入列表,最后把列表转为为字符串

d = {'k':'1','k1':'2','k2':'3','k3':'4'}result = []
for k,v in d.items():lst = []lst.append(k)lst.append(v)item = ":".join(lst)result.append(item)
print("|".join(result))

在这里插入图片描述

d = {'k':'1','k1':'2','k2':'3','k3':'4'}result=""
for k,v in d.items():result+=(k+":"+v+"|")
print(result[:len(result)-1])

在这里插入图片描述

这篇关于python习题库132-142的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/737961

相关文章

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

Python xmltodict实现简化XML数据处理

《Pythonxmltodict实现简化XML数据处理》Python社区为提供了xmltodict库,它专为简化XML与Python数据结构的转换而设计,本文主要来为大家介绍一下如何使用xmltod... 目录一、引言二、XMLtodict介绍设计理念适用场景三、功能参数与属性1、parse函数2、unpa

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

Python中@classmethod和@staticmethod的区别

《Python中@classmethod和@staticmethod的区别》本文主要介绍了Python中@classmethod和@staticmethod的区别,文中通过示例代码介绍的非常详细,对大... 目录1.@classmethod2.@staticmethod3.例子1.@classmethod

Python手搓邮件发送客户端

《Python手搓邮件发送客户端》这篇文章主要为大家详细介绍了如何使用Python手搓邮件发送客户端,支持发送邮件,附件,定时发送以及个性化邮件正文,感兴趣的可以了解下... 目录1. 简介2.主要功能2.1.邮件发送功能2.2.个性签名功能2.3.定时发送功能2. 4.附件管理2.5.配置加载功能2.6.

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写