zoukankan      html  css  js  c++  java
  • 算法

    二分法:

    n = 100
    li = list(range(n))
    
    def bin_search(li,val):
        low = 0
        high = len(li) - 1
        while low <= high:
            mid = (low + high) // 2
            if li[mid] == val:
                return mid
            elif li[mid] < val:
                low = mid + 1
            else:
                high = mid - 1
        return None
    
    
    obj = bin_search(li,33)
    print(obj)
    View Code
    # 算法网址  https://leetcode.com/problems/two-sum/description/
    
    
    #方式一:
    
    def two_sum(li,target):
        l = len(li)
        for i in range(l):
            for j in range(i+1,l):
                if li[i] + li[j] == target:
                    return (i,j)
        return None
    
    
    obj = two_sum([2,7,11,15],18)
    print(obj)
    
    
    
    #方式二:
    
    def bin_search(data_set, value):
        low = 0
        high = len(data_set) - 1
        while low <= high:
            mid = (low + high) // 2
            if data_set[mid] == value:
                return mid
            elif data_set[mid] > value:
                high = mid - 1
            else:
                low = mid + 1
    
    def two_sum2(li, target):
        li.sort()
        for i in range(len(li)):
            b = target - li[i]
            j = bin_search(li, b)
            if j != None and i != j:
                return i, j
    
    obj = two_sum2([2, 7, 11, 15], 18)
    print(obj)
    
    #方式三:
    
    def two_sum3(li,target):
        li.sort()
        i = 0
        j = len(li) - 1
        while i < j:
            sum = li[i] + li[j]
            if sum > target:
                j-=1
            elif sum < target:
                i+=1
            else:
                return (i,j)
        return None
    
    obj = two_sum3([2,7,11,15],18)
    print(obj)
    算法练习

    排序:

    #冒泡排序
        - 列表每相邻的数,如果前面的比后面的大,那么交换这两个数
        -算法复杂度 n^2
    
    
    def bubble_sort(li):
    
        for i in range(len(li) - 1):
            for j in range(len(li) - i -1):          # i 趟
                if li[j] > li[j+1]:
                    li[j+1],li[j] = li[j],li[j+1]    # j 指针
        return li
    
    li = [9,1,5,3,7]
    print(bubble_sort(li))
    冒泡排序
    #选择排序
        - 一趟遍历记录 最小的数,放到第一个位置。再一趟遍历记录剩余列表中最小的数,继续放置
        - 时间复杂度 O(n^2)
    
    
    def select_sort(li):
        for i in range(len(li) - 1):
            min_loc = i
    
            # 找i+1位置到最后位置内 最小的数
            for j in range(i+1,len(li)):
                if li[j] < li[min_loc]:
                    min_loc = j
    
            # 和无序区第一个数 做交换
            li[i],li[min_loc] = li[min_loc],li[i]
        return li
    
    
    li = [9,3,7,1]
    print(select_sort(li))
    选择排序
    #插入排序
        - 列表被分为有序区和无序区 最初有序区只有一个元素
        - 每次从无序区选择一个元素 插入到有序区的位置 直到无序区变空
    
    
    #方式一:
    
    def insert_sort(li):
        for i in range(1,len(li)):  # i 代表每次摸到牌的下标
            tmp = li[i]
            j = i-1   # j代表手里最后一张牌的下标
            while True:
                if j<0 or tmp>=li[j]:
                    break
                li[j+1] = li[j]
                j -= 1
            li[j+1] = tmp
        return li
    
    obj = insert_sort([1,8,6,2,5,3])
    print(obj)
    
    
    #方式二:
    
    def insert_sort(li):
        for i in range(1,len(li)):  # i 代表每次摸到牌的下标
            tmp = li[i]
            j = i-1   # j代表手里最后一张牌的下标
            while j>=0 and tmp<li[j]:
                li[j+1] = li[j]
                j -= 1
            li[j+1] = tmp
        return li
    
    obj = insert_sort([1,8,6,2,5,3])
    print(obj)
    插入排序
    def partition(data,left,right):
    
        tmp = data[left]
        while left < right:
            # right 左移动
            while left < right and data[right] >= tmp:   #如果low和high没有相遇且后面的数一直大于第一个数 就循环
                right -=1
            data[left] = data[right]
            # left 右移动
            while left < right and data[left] <= tmp:   #如果low和high没有相遇且后面的数一直大于第一个数 就循环
                left +=1
            data[right] = data[left]
        data[left] = tmp
        return left
    
    
    def quick_sork(data,left,right):
    
        if left <right:
            mid = partition(data,left,right)
            quick_sork(data,left,mid-1)
            quick_sork(data,mid+1,right)
        return data
    
    
    alist = [33,22,11,55,33,666,55,44,33,22,980]
    
    obj = quick_sork(alist,0,len(alist)-1)
    print(obj)
    快速排序
  • 相关阅读:
    哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)I
    哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)F
    哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)H
    哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)E
    哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)G
    哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)C
    哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)D
    哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)A
    哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)B
    HDU 6187 Destroy Walls
  • 原文地址:https://www.cnblogs.com/zhaochangbo/p/7749224.html
Copyright © 2011-2022 走看看