Python练习实例
输入三个整数x,y,z,请把这三个数由小到大输出。
(出处:https://www.runoob.com/python/python-exercise-example5.html)
拿到这道题后,我就用最笨的方法把它写了出来,并进行了优化。
'''
x = int(input('请输入一个整数X:'))
y = int(input('请输入一个整数Y:'))
z = int(input('请输入一个整数Z:'))
if x <= y:
if y <= z:
print(x,y,z)
elif z <= y:
if x <= z:
print(x,z,y)
else:
print(z,x,y)
if x >= y:
if z <= y:
print(z,y,x)
elif z >= y:
if x <= z:
print(y,x,z)
else:
print(y,z,x)
'''
但显然,这种方法只是数字之间相比较,确实有点显得low了
于是我就用了另一个办法:建立一个列表用选择排序法来处理
'''
x = int(input('请输入一个数字X:'))
y = int(input('请输入一个数字Y:'))
z = int(input('请输入一个数字Z:'))
array = [x,y,z] #开头输入,定义一个列表
def bubble_sort():
for idx in range(len(array)): #建立两个循环,让数列中的数一个一个进行比较
for j in range(idx+1,len(array)):
if array[idx] > array[j]:
array[idx] , array[j] = array[j] , array[idx] #该处是让数字交换,使小的数字往前走(冒泡)
return array #返回函数值
bubble_sort() #调用函数,使函数内部代码运行一遍
for i in array:
#一个个打印出数列里的内容,此处也可以直接打印数列 print(array)或者打印函数 print(bubble_sort)
print(i, end=' ')
'''
这里我就用到了循环语句(我把这个语句块写在了一个函数里,不用定义也可以,个人习惯)
一遍遍的循环使相邻两数相比较,将小的数字排在前面
这样的循环呢,就又产生了另一种思路,也被称为冒泡排序法
'''
x = int(input('请输入一个整数X:'))
y = int(input('请输入一个整数Y:'))
z = int(input('请输入一个整数Z:'))
array = [x,y,z]
def bubble_flag(list):
length = len(list)
for index in range(length):
for i in range(1,length - index):
if list[i-1] > list[i]:
list[i] , list[i-1] = list[i-1] , list[i]
return list
bubble_flag(array)
for i in array:
print(i,end=' ')
'''
这里大家就会看到了,其实与上面的代码(选择排序法)没有什么不同,不过冒泡排序法是将大的数字往后放(我感觉叫沉底法还比较贴切)
写到这里对于开头的实例来说已经完成了任务,但我并不满足
输入数字改进
第一种方法运算量少但不可避免的有个弊端:如果有几百甚至几万个数字呢?
显然,它满足不了了,所以我选择后两种方法重新进行了加工,我把前面的数字数量写成了一个函数包
'''
def sort_input_MoreNumber(list):
array = list
number = int(input('请问您要输入几个数字:'))
for i in range(number):
x = int(input('请输入一个数字以加入要排序的数列: '))
array.append(x)
return array
'''
这时候只需要定义一个空列表,再引用函数就可以实现了
但这种方法还是不太好,当列表数字太多的时候,输入的时候可能会输入错误,并且这样的话还要再去数一下一共有多少数字
这时候就可以在用另一个方式去输入,输入的时候用一个循环使使用者能看到自己输入了第几个数字,并无限循环
而当输入QUIT时退出循环进行排序,这里我就不给出代码了
最后,给出一个排序方法,这个排序方法对于以后来说效率更高,但对于初学者来说,自己编写可以锻炼思维
所以这个方法不推荐初学者使用
'''
list.sort()
'''
没错,非常简短,这就是Python内置的函数,可以使我们开发效率更快,没有必要再去冗长的编写代码了
到此,这节笔记就结束了
end