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生成固定格式序号的方法详解

《使用python生成固定格式序号的方法详解》这篇文章主要为大家详细介绍了如何使用python生成固定格式序号,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录生成结果验证完整生成代码扩展说明1. 保存到文本文件2. 转换为jsON格式3. 处理特殊序号格式(如带圈数字)4

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

Python打包成exe常用的四种方法小结

《Python打包成exe常用的四种方法小结》本文主要介绍了Python打包成exe常用的四种方法,包括PyInstaller、cx_Freeze、Py2exe、Nuitka,文中通过示例代码介绍的非... 目录一.PyInstaller11.安装:2. PyInstaller常用参数下面是pyinstal

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型: