请问哪里的问题第一次写python (Binary Search)
高洛峰
高洛峰 2016-11-16 13:39:14
0
2
864
#!/usr/bin/python

""" 折半查找算法
"""

#定义函数

def BinarySearch(a, X, N):
    left, right = 0, N-1
    while (left <= right):
        middle = ( left + right ) / 2
        if (X < a[middle]):
            right = middle - 1
        elif (X > a[middle]):
            left = middle + 1
        else:
            return middle
    return -1 #"not found"

#调用函数

arr = [10,20,30,40,50,60,70]
BinarySearch(arr, 40, len(arr))


高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

membalas semua(2)
三叔
#!/usr/bin/python
# -*- coding: utf-8 -*-
import random
# generate an unsorted list
def generate_unsorted_list(num):
    unsorted_list = []
    for i in range(0, num):
        unsorted_list.append(random.randint(0, 30))
    print unsorted_list
    return unsorted_list
def binary_search(target, sorted_list):
    list_length = len(sorted_list)
    start, end = 0, list_length-1
    if list_length == 0:
        print 'empty list'
        return -1
    while start < end:
        middle = (start+end)/2
        if target == sorted_list[middle]:
            print 'find index:', middle
            return middle
        elif target < sorted_list[middle]:
            end = middle-1
        else:
            start = middle+1
    print 'not find'
    return -1
if __name__ == "__main__":
    unsorted_list = generate_unsorted_list(20)
    sorted_list = sorted(unsorted_list)
    print sorted_list
    binary_search(14, sorted_list)


学霸
#!/usr/bin/python
# -*- coding: utf-8 -*-
import random
# generate an unsorted list
def generate_unsorted_list(num):
    unsorted_list = []
    for i in range(0, num):
        unsorted_list.append(random.randint(0, 30))
    print unsorted_list
    return unsorted_list
def binary_search(target, sorted_list):
    list_length = len(sorted_list)
    start, end = 0, list_length-1
    if list_length == 0:
        print 'empty list'
        return -1
    while start < end:
        middle = (start+end)/2
        if target == sorted_list[middle]:
            print 'find index:', middle
            return middle
        elif target < sorted_list[middle]:
            end = middle-1
        else:
            start = middle+1
    print 'not find'
    return -1
if __name__ == "__main__":
    unsorted_list = generate_unsorted_list(20)
    sorted_list = sorted(unsorted_list)
    print sorted_list
    binary_search(14, sorted_list)


Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan