六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 46|回复: 0

二分查找

[复制链接]

升级  58%

37

主题

37

主题

37

主题

秀才

Rank: 2

积分
137
 楼主| 发表于 2013-1-26 12:34:41 | 显示全部楼层 |阅读模式
讲解if-else语句,就以二分查找举例,实在给力。
/* find x in v[0] <= v[1] <= ... <= v[n-1] */int binsearch(int x, int v[], int n){int low = 0;int high = n - 1;int mid;while (low <= high) {mid = (low + hight)/2;if (x < v[mid])high = mid - 1;else if (x > v[mid])low = mid + 1;elsereturn mid;}return -1;}/* Exercise 3-1 using only one test inside the loop */int binsearch(int x, int v[], int n){int low = 0;int high = n - 1;int mid;while (low < high) {mid = (low + high)/2;if (x <= v[mid])high = mid;elselow = mid + 1;}return (x == v[low]) ? low : -1;}
摘自《The C Programming Language》 Chapter 3
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表