二分查找时mid的计算方法
2016-10-21 21:34
204 查看
如果用mid=(low+high)/2,在运行二分查找程序时可能超时。
原因是int类型最大表示范围是2147483647,详细分析见我之前的一篇文章点击打开链接
如果输入的low和high都接近2147483647,两个数相加就会溢出,变成一个负数。
例:
所以如果想避免溢出,不能使用mid=(low+high)/2,应该使用mid=low+(high-low)/2。
因为mid=(low + high)/2=(low + low + high - low)/2=(2*low + high - low)/2=low + (high - low)/2
使用mid=low+(high-low)/2,避开了(low + high),能避免int类型整数的溢出。
原因是int类型最大表示范围是2147483647,详细分析见我之前的一篇文章点击打开链接
如果输入的low和high都接近2147483647,两个数相加就会溢出,变成一个负数。
例:
#include<stdio.h> int main(){ int low = 2147483647; int high = 2147483646; printf("%d\n", low + high); return 0; }
所以如果想避免溢出,不能使用mid=(low+high)/2,应该使用mid=low+(high-low)/2。
因为mid=(low + high)/2=(low + low + high - low)/2=(2*low + high - low)/2=low + (high - low)/2
使用mid=low+(high-low)/2,避开了(low + high),能避免int类型整数的溢出。
相关文章推荐
- 递归的定义以及递归的示例(计算阶乘、计算斐波那契数、递归二分查找、回文串递归方法解决、汉诺塔问题、递归选择排序问题)
- [整理]二分查找搜索算法原理及递归,迭代方法实现
- 佣金计算详解02:获取目标值(比较项:一个或多个)二分查找
- 准确实现二分查找方法
- 【算法学习笔记】52.一道题的三种方法..二分答案、动态规划、计算几何 SJTU OJ 1250 BestSubsequence
- #1128 : 二分·二分查找 ( 两种方法 先排序在二分O(nlogN) + 直接二分+快排思想O(2N) )
- 二分查找 数组和指针方法
- 二分查找时间复杂度的计算
- poj 1905 Expanding Rods (数学 计算方法 二分)
- 算法---二分查找方法
- 二分查找的两种实现方法
- HDU 2871 Memory Control 线段树(区间合并)+二分查找+vector的常用方法
- 一个可能存在Bug的二分查找方法的实现,大家一起看看有什么问题没
- Java 查找方法(普通查找,二分查找)
- 通过二分的方法查找小于n的素数的个数
- 二分查找时间复杂度的计算(转)
- ruby数组和哈希表的区别,递归,二分查找方法
- shell中计算字符串长度的方法 查找,替换
- 三种方法实现二分查找
- 冒泡 选择 插入排序 顺序 二分查找方法