• 02python算法-二分法简介


    老规矩:

    什么是二分法:

      其实是一个数学领域的词,但是在计算机领域也有广泛的使用。

    为什么需要二分法?

          当穷举算法性能让你崩溃时。

    二分法怎么用呢?

          让我们先玩一个游戏先,我心里想一个100以内的整数你来猜猜。那么你可以从1-100这么猜,当然如果我说我想的10000以内的,那么迭代次数线性上升。。。你懂的
          当然你可以先设一个猜想数,我们可以采用2分之一的方法猜,首先是50 那么比50大的化就在50-100取2分之一为猜想数,继续。当然2分法不一定是2分之一,只是取决 

          于答案出现的区间十分有规律性,如果你知道小明老是喜欢猜比较小的数,你会不会一直都用2分之一呢?

    我们可以看下用二分法排序的代码

    def quick (L, low, high):
        i = low 
        j = high
        if i >= j:
            return L
        key = L[i]
        while i < j:
            while i < j and L[j] >= key:
                j = j-1                                                             
            L[i] = L[j]
            while i < j and L[i] <= key:    
                i = i+1 
            L[j] = L[i]
        L[i] = key 
        quickSort(L, low, i-1)
        quickSort(L, j+1, high)
        return L
    

      很简单吧,这个是用递归实现的,核心依然是猜想数. 先设置一个猜想数,然后比猜想大的在右边,比猜想数小的在左边。然后把一个列表分成两个,然后接着对这两个列表做同样的操作。

  • 相关阅读:
    transition
    Java自增陷阱
    不同编码格式中,字节和字符的关系
    表单重复提交
    source folder和package的区别
    @test 测试案例不能添加参数
    http协议content-type
    jdbc的缺点和mybatis的优点
    ==和equals的区别
    spring IOC和AOP
  • 原文地址:https://www.cnblogs.com/nerdlerss/p/5628069.html
Copyright © 2020-2023  润新知