python循环

复制代码
#for循环之二分查找
def seek(targe=66,arr=[11,22,33,68],left=0,right=3):
    while left<right:
         mid=(left+right)//2
         i=arr[mid]
         if i==targe:
             return mid+1
         elif i>targe:
             right=mid-1
             #seek(targe,arr,left,right)
         else:
            left=mid+1
            #seek(targe,arr,left,right)
    return -1
复制代码

 

复制代码
#while循环合并2个有序的数组,这是归并排序的重点
def sort(arr1,arr2):
    i,j,k=0,0,0
    arr3=[]
    while(i<len(arr1) and j<len(arr2)):
        if arr1[i]<arr2[j]:
            arr3.insert(k,arr1[i])
            i+=1
            k+=1
        else:
            arr3.insert(k,arr2[j])
            j+=1
            k+=1

    while i<len(arr1):
        arr3.insert(k,arr1[i])
        i+=1
        k+=1
    while j<len(arr2):
        arr3.insert(k,arr2[j])
        j=j+1
        k=k+1
    for  elem in arr3:
        print(elem,end=" ")

arr1=[1,3,5,7]
arr2=[2,4,6,8,78]
sort(arr1,arr2)
复制代码

 

posted @   睡到自然醒ccc  阅读(226)  评论(0编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示