BinarySearch

#!/usr/bin/python

#define initial index 0, and max index length-1

#find  ip_num in ip_lib_list

ip_num = 15
ip_lib_list = [[2, 2, 3], [5, 3, 4], [7, 4, 5], [8, 5, 6], [12, 7, 8],[15, 9, 0], [19, 0, 1]]

low_index = 0
mid_index = 0
high_index = len(ip_lib_list) - 1
char = 0

while (low_index < high_index):
#define mid_index initial value equal half of low index and high index
        mid_index = int((low_index + high_index) / 2)
        sss = ip_lib_list[mid_index]
        start_ip = sss[0]

        if ip_num < start_ip:
            high_index = int(mid_index - 1)
        if ip_num > start_ip:
            low_index = int(mid_index + 1)
        elif ip_num == start_ip:
            char = ip_lib_list[mid_index]
#if the value we want is find now, then skip next loops
            low_index = high_index
#if we already find the value, then just print out
#if not, it means either the ip_num in low_index=0 or high_index=len(ip_lib_list) - 1
if char == 0:
    if ip_num < start_ip:
        provice = ip_lib_list[mid_index-1]
        print("%s" % (provice))
    else:
        mid_index = int((low_index + high_index) / 2)
        provice = ip_lib_list[mid_index]
        print("%s" % (provice))
else:
    print("%s" % (char))

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SeasonRun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值