python习题库143-159

2024-02-23 07:48
文章标签 python 习题 143 159

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

习题143、生成一个新列表,-1的左边都是小于它的,右边都是大于它的。a= [-1,2,3,-3,0,-5,5]

a = [-1,2,3,-3,0,-5,5]
base = a[0]
list1=[]
list2=[]
for num in a:if num <base:list1.append(num)else:list2.append(num)
print(list1 + [base] + list2)

在这里插入图片描述

习题144、在列表[100, 2, 3, -3, 0, -5, 5]中实现每个元素+1,需要在原列表实现

a=[100,2,3,-3,0,-5,5]
for i in range(len(a)):a[i]+=1
print(a)

在这里插入图片描述

>>> a=[100,2,3,-3,0,-5,5]
>>> [x+1 for x in a]
[101, 3, 4, -2, 1, -4, 6]
>>>
>>> a=[100,2,3,-3,0,-5,5]
>>> list(map(lambda x:x+1,a))
[101, 3, 4, -2, 1, -4, 6]

在这里插入图片描述

习题145、在列表中插入一个新的元素[100, 2, 3, -3, 0, -5, 5]在0的前面插入一个元素10000

算法
1 遍历,判断是否0,不是0,把元素插入新列表
2 是0,则把带插入元素插入新列表,然后再插入0
方法1

a=[100,2,3,-3,0,-5,5]
result=[]
target_num=10000
for i in a:if i == 0:result.append(target_num)result.append(i)else:result.append(i)
print(result)

在这里插入图片描述
算法:按索引遍历列表,找到0的位置,插入1000,结束遍历
方法2

a=[100,2,3,-3,0,-5,5]
for i in range(len(a)):if a[i]==0:a.insert(i,10000)break
print(a)

在这里插入图片描述

习题145、列表中的第三个位置插入10000

算法:使用切片把第三个位置前的取到使用切片把位置三后的取到把10000存到一个列表,三个列表相加

a=[100,2,3,-3,0,-5,5]
result=[]
target_num=10000
result=a[:2]+[target_num]+a[2:]
print(result)

在这里插入图片描述

习题146、[1,-1,2,-2,3,-3] 利用max()排序

按长度遍历列表,每次把最大值添加到一个列表,把最大值插入到另一个列表的0位置

a=[1,-1,2,-2,3,-3]
result_asc=[]
result_desc=[]
for i in range(len(a)):result_desc.append(max(a))result_asc.insert(0,max(a))a.remove(max(a))
print("升序:",result_asc)
print("降序:",result_desc)

在这里插入图片描述
利用min()函数升序

a=[1,-1,2,-2,3,-3]
result=[]
for i in range(len(a)):result.append(min(a))a.remove(min(a))
print(result)

在这里插入图片描述

习题147、a = "abcdefghi"把开头、结尾、中间位置的字母变为1其他字母不变

s="abcdefghi"
a=list(s)
if len(a)%2==1:a[0],a[-1],a[len(a)//2]="1","1","1"
else:a[0],a[-1],a[len(a)//2-1:len(a)//2+1]="1","1","1"
print("".join(a))

在这里插入图片描述

习题148、找到英文句子中最长的单词

方法1
利用sort函数,按照单词长度排序

s = "I am a boyboy! hi,glory road"for v in s:if not v.isalpha():s = s.replace(v," ")
l = s.split()l.sort(key=len,reverse=True)
#l.sort(key=lambda x:len(x))print(l[0])

在这里插入图片描述
直接找最大值

s = "I am a boyboy! hi,glory road"for v in s:if not v.isalpha():s = s.replace(v," ")
l = s.split()
max_length=0result=[]
for v in l:if max_length<len(v):max_length=len(v)
for v in l:if len(v)==max_length:result.append(v)
print(result[0])

在这里插入图片描述

习题149、利用推导列表生成10 - 30

>>> [int(x+y) for x in"123" for y in "0123456789" if int(x+y)<=30]
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30]
>>> [int(x+y) for x in "123" for y in map(str,range(10)) if int(x+y)<=30]
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30]

在这里插入图片描述

习题150、用推导列表求所有数字key的和

>>> d={1:"a",2:"b","a":3}
>>> sum([k for k in d if isinstance(k,(int,float))])
3

在这里插入图片描述

习题151、"abcdefgh"里面挑出3个字母进行组合,一共有多少种组合,要求三个字母中不能有任何重复的字母,三个字母的同时出现次数,在所有组合中只能出现一次,例如出现abc了,不能出现cab和bca等

s = "abcdefgh"
result = []
temp_list = []
for k in s:for v in s:for j in s:if k != v and k != j and v !=j:if sorted(list(k+v+j)) not in [sorted(s) for s in result]:result.append(k+v+j)#print(result)
print("组合数:",len(result))

在这里插入图片描述

习题152、复制一个列表,不能使用切片和复制的函数进行赋值,尽可能使用少的内置函数

方法1

lst=["a","b","c","d","e"]length=0
i=0
for v in lst:length+=1
result=[None]*lengthwhile i<length:result[i]=lst[i]i+=1
print("复制后的列表为:",result)

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

a=["a","b","c","d","e"]
arr_length=0for i in a:arr_length+=1def iter_arr(n):arr=[]i=0while i<=n-1:arr+=[i]i+=1return arr
result=[""]*arr_lengthfor i in iter_arr(arr_length):result[i]=a[i]
print(result)

在这里插入图片描述

习题153、d={-1:100,-2:200,0:300,-3:200}按照key的大小顺序升序进行输出,输出key=value -3=200,-2=200,-1=100,0=300

d={-1:100,-2:200,0:300,-3:200}for k in sorted(d.keys()):print("%s=%s"%(k,d[k]),end=",")

在这里插入图片描述

d={-1:100,-2:200,0:300,-3:200}for k,v in sorted(d.items(),key=lambda x:x[0]):print(str(k)+"="+str(v),end="")

在这里插入图片描述

习题154、一个字符串排序,排序规则:小写<大写<奇数<偶数,

原理:先比较元组的第一个值,FALSE<TRUE,如果相等就比较元组的下一个值,以此类推。

s="9a13C85c7B24A6b"s=sorted(list(s))lst=sorted(s,key=lambda x:(x.isdigit(),x.isdigit() and int(x)%2==0,x.isalpha() and
x.isupper(),x.isalpha() and x.islower()))
print("".join(lst))

在这里插入图片描述

习题155、生成一个字典,key 是26个小写字母a-z,value是她的acsii码

d={}for k in range(97,123):d[chr(k)]=k
print(d)

在这里插入图片描述

>>> {chr(i):i for i in range(97,123)}

在这里插入图片描述

习题156、从键盘输入两个数,并比较其大小,直到输入e/E退出程序

while 1:first=input("请输入第一个数或e退出程序:")if first.lower()=="e":breaksecond = input("请输入第二个数或e退出程序:")if second.lower()=="e":breakif first>second:print("%s 大"%first)elif first<second:print("%s 大"%second)else:print("等于")

在这里插入图片描述

习题157、将列表元素交替地作为建和值来创建字典

lst=list(range(10))
d={}
for i in range(0,len(lst),2):d[lst[i]]=lst[i+1]
print(d)

在这里插入图片描述

习题158、分别输出字符串中奇数坐标和偶数坐标的字符

s="abcdefghijkl"
for i in range(0,len(s),2):print("偶数坐标字符:",s[i])
print("奇数坐标字符:",s[i+1])

在这里插入图片描述

习题159、将一个字典的 key和value 互换

dit=dict(name="wwqq",sex="M")
dit1=dict([("a",1),("b",2),("c",3)])
dit2=dict(zip([1,2,3],[3,4,5]))
print(dit,dit1,dit2)
result={}
for k,v in dit1.items():result[v]=k
print("key和value交换后:",result)

在这里插入图片描述

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



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

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

Python QT实现A-star寻路算法

目录 1、界面使用方法 2、注意事项 3、补充说明 用Qt5搭建一个图形化测试寻路算法的测试环境。 1、界面使用方法 设定起点: 鼠标左键双击,设定红色的起点。左键双击设定起点,用红色标记。 设定终点: 鼠标右键双击,设定蓝色的终点。右键双击设定终点,用蓝色标记。 设置障碍点: 鼠标左键或者右键按着不放,拖动可以设置黑色的障碍点。按住左键或右键并拖动,设置一系列黑色障碍点

Python:豆瓣电影商业数据分析-爬取全数据【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】

**爬取豆瓣电影信息,分析近年电影行业的发展情况** 本文是完整的数据分析展现,代码有完整版,包含豆瓣电影爬取的具体方式【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】   最近MBA在学习《商业数据分析》,大实训作业给了数据要进行数据分析,所以先拿豆瓣电影练练手,网络上爬取豆瓣电影TOP250较多,但对于豆瓣电影全数据的爬取教程很少,所以我自己做一版。 目