在刚开始接触算法时,我们可能一脸懵,不知从何处下手,尤其是现在使用的语言五花八门,各种语言的实现又不尽相同,所以,在这种情况下,千万不能迷失了自己,掌握了算法的原理,就像解数学公式一样,定理给你了,仔细想想便可以用代码来实现它,前提要养成良好的解题思路.
下面我们来从入门的排序算法开始:
以下都是针对一个无序数组 A = [3,1,5,6,7,2,4,8] 进行排序
1.简单的冒泡排序
初进排序算法,那就来试一下冒泡吧,原理和暴力枚举法差不多,极尽可能的把所有元素都枚举出来,一个个对比,做法简单而又粗暴(很*很暴力).
下面上代码:
'''
冒泡排序算法
'''
def bubblesorft(A):
for i in range(len(A)):#第一层循环,控制排序的次数
for j in range(len(A)-i):#第二层循环,控制前一个元素与后一个元素比大小
if j+1 < len(A):
if A[j] > A[j+1]:
temp = A[j+1]
A[j+1] = A[j]
A[j] = temp
return A
A = [3,1,5,6,7,2,4,8]
A = bubblesorft(A)
print(A)
[1, 2, 3, 4, 5, 6, 7, 8]
算法简单,清晰明了,如果看不懂,那就自己敲几遍代码,你很快就会悟了,哈哈
这都不算完,接下来上个简单而又不简单的归并排序算法,你再来悟一下:
2.简单而又不简单的归并排序
说简单是因为你悟透了,说不简单是递归很绕人,其实想明白了何时return,就想明白了此时递归的值.
归并排序在排序时先将数组分成两部分,并分别进行排序,然后再把排好序的两部分整合成一个排序数组.
下面上代码感受一下:
'''
归并排序算法
'''
def mangesorft(A):
if len(A) <= 1:
return A
half = int(len(A) / 2)#把列表分成两份
first = mangesorft(A[0:half])#使用了递归,使得最后分的元素越来越小,直至到一个元素,然后返回排序好的列表
second = mangesorft(A[half:len(A)])#使用了递归,使得最后分的元素越来越小,直至到一个元素,然后返回排序好的列表
i = 0
j = 0
newA = []
while i < len(first) or j < len(second):#控制循环次数
if i
if first[i] <= second[j]:
newA.append(first[i])
i += 1
else:
newA.append(second[j])
j += 1
else:
if i < len(first):
newA.append(first[i])
i += 1
if j < len(second):
newA.append(second[j])
j +=1
return newA
if __name__ == "__main__":
A = [3,1,5,6,7,2,4,8]
A = mangesorft(A)
print(A)
[1, 2, 3, 4, 5, 6, 7, 8]
对比这两个算法,你有啥想法了没有,如果有,那么恭喜你,咱们可以一起拉着小手跳入算法的坑了,
有了这两个神器,以后遇到算法问题,对于无序的数组或列表,那咱就先来排个序吧,这可是解题的第一步,加油!
顺带讲两个列表和数组去重的小知识(有面试题考过):
A = [1,1,2,2,3,3,4,4,5,5,6,6,7,7]
#普通方法去重
newA = []
def deletequemnents(A):
for i in A:
if i in A:
if i not in newA:
newA.append(i)
return newA
print(deletequemnents(A))
#使用python内置函数set去重
def deletequemn(A):
for i in A:
A = set(A)
return A
print(deletequemn(A))