Python基础教程:7个经典程序示例(1)

for index in range(len(m) - time):

if m[index] > m[index+1]:

m[index], m[index+1] = m[index+1] , m[index]

return m

选择排序

def selectSort(m):

m = m.copy()

for seat_L in range(len(m)-1):

for seat_R in range(seat_L+1, len(m)):

if m[seat_L] > m[seat_R]:

m[seat_L], m[seat_R] = m[seat_R], m[seat_L]

return m

插入排序1(内部写成函数):

def insertSort_1(m):

result = []

单个元素k插入列表li

def to_insert(li, k):

标识符

tab = False

寻找插入位置

循环次数应该至少大于列表长度+1,None也占一位(空列表),即认为扑克牌最末尾还有一张‘空牌’

for i in range(len(li) + 1):

修改标识符,标志‘遍历完后的下一个循环’,即在和‘空牌’比较

if i == (len(li)):

tab = True

如果在对li[-1]比较完成(包含)之前,且寻找到位置,即把扑克从左往右比较一遍

if not tab and k < li[i]:

li.insert(i, k)

break

如果遍历完成,多循环一次,即和‘空牌’不需要比较,直接把牌替换掉‘空牌’

if tab:

li.append(k)

return li

遍历列表

result = result[:1]

for length in range(len(m)):

result = to_insert(result, m[length])

print(result,m[length])

return result

插入排序2(直接嵌套循环):

def insertSort2(m):

m = m.copy()

result = m[:1]

for index_choose in range(1, len(m)):

手上已经有index_choose张牌,比较第index_choose+1张牌则append

逐个比对手上的牌,如果都对比了一遍,则加到最后

for index_insert in range(len(result) + 1):

print(result, index_insert,‘\n’,m, index_choose,‘\n\n’)

if index_insert != index_choose and m[index_choose] < result[index_insert] :

result.insert(index_insert, m[index_choose])

break

if index_insert == index_choose:

result.append(m[index_choose])

print(result, m[index_choose])

return result

print(li)

print(‘插入排序:’,insertSort3(li))

print(‘选择排序:’,selectSort(li))

print(‘冒泡排序:’,bubbleSort(li))

que6()

2.调换字典键值

1. 调换元素.\

def que1():

d={1:“one”,2:“two”}

方法1 — 动态赋值

def method1(d):

d = d.copy()

result = {}

for k,v in d.items():

result[v] = k

return result

方法2 — 生成器

def method2(d):

d = d.copy()

result = {v:k for k,v in d.items()}

return result

方法3 — 由值寻找键

def method3(d):

d = d.copy()

由键寻找值

def match(dic, b):

return [k for k,v in dic.items() if v == b]

先生成key-None,再赋值

result = {}

result = result.fromkeys(d.values())

for k in result.keys():

result[k] = match(d, k)[0]

return result

方法4 — 列表转字典 < 直接转换/动态赋值 >

def method4(d):

d = d.copy()

key = d.keys()

val = d.values()

data = list(zip(key, val))

方法4-1

result1 = {}

for i in range(len(data)):

result1[data[i][1]] = data[i][0]

方法4-2

result2 = dict(zip(val, key))

return result1, result2

print(‘新列表动态赋值方法:{}’.format(method1(d)))

print(‘生成器方法:{}’.format(method2(d)))

print(‘由键寻值方法:{}’.format(method3(d)))

print(‘动态赋值列表转字典方法:{}’.format(method4(d)[0]))

print(‘直接列表转字典方法:{}’.format(method4(d)[1]))

que1()

3.删除列表中的重复元素

‘’’

遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025

寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!

‘’’

3. 删除重复元素list =[1,2,5,4,1,5,6,8,0,2,5]

a = np.random.randint(-100, 100, size=10)

a = a.tolist()

def method1(a):

a = a.copy()

a = set(a)

return a

def method2(a):

b = a.copy()

c = 0

for i in range(len(a)-1):

if b[i+c] in b[:i+c]+b[i+c+1:]:

b.pop(i+c)

c -= 1

return b

print(‘集合法:’,method1(a))

print(‘遍历法:’,method2(a))

4.输出质数

def prime(end):

prime_list = []

if end <= 1:

print(‘必须大于1’)

else:

prime_list.append(2)

for i in range(2, end+1, 1):

count = 0

if i == 2:

if i%2 != 0:

prime_list.append(2)

else:

for m in range(2, i):

能够整除,则跳出循环

if (i % m) == 0:

print(i, m)

break

否则计数+1

else:

count += 1

判断是否整除完成(0/n)

if count == i - 2:

prime_list.append(i)

print(count, i, m)

return (prime_list)

num = int(input(‘想输出2到多少?’))

print(prime(num))

5.判断是一年中第几天

def que3():

3.输入某年某月某日,判断这一天是这一年的第几天?:

闰年判断函数

def judge_leap(num):

date = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]

(四年一闰 and not百年) or 四百年闰

if (num % 4 == 0 and num % 100 != 0) or num % 400 ==0:

date[1] =29

return date

格式转换

date = (input(‘请输入一个日期,格式如:“2018.02.12”:’))

date_list = (list(map(int, (date.split(‘.’)))))

遍历计算天数

day = date_list[2]

for i in range(date_list[1]):

day += judge_leap(date_list[0])[i]

print(‘{}月{}日是{}年的第{}天\n’.format(date_list[1], date_list[2], date_list[0], day))

que3()

6.猜数字

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注:Python)

CO2-1713637372369)]

[外链图片转存中…(img-TwPibjic-1713637372370)]

[外链图片转存中…(img-UaOiql53-1713637372371)]

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注:Python)

  • 23
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值