二分算法C实现

简介: #include #include #define NR(x) (sizeof(x)/sizeof(x[0]))int BinarySerach(int a[],int size,int p){ int L = 0 ; //查找区间的左端点 int R = size - 1...
#include <stdio.h>
#include <stdlib.h>
#define  NR(x)  (sizeof(x)/sizeof(x[0]))

int BinarySerach(int a[],int size,int p)
{
	int L = 0 ; 	//查找区间的左端点 
	int R = size - 1 ; //查找区间的右端点 
	int mid ;
	while(L <=  R)  //如果查找区间不为空就继续查找 
	{
		mid = L + (R-L)/2 ; //取到查找区间正中元素的下标 
		if(p == a[mid]) 
			return mid ; //返回对应数组元素的下标
		else if(p > mid) 
			L = mid + 1 ;  //设置新的查找区间的左端点 
		else 
			R = mid - 1 ;  //设置新的查找区间的右端点 
	}
	return -1 ;
}

int main(void)
{ 
	int a[9] = {1 , 2 ,3 , 4 , 5 , 6, 7 , 8 , 9}; 
	int ret ; 
	ret = BinarySerach(a,NR(a),8);
	//返回查找到的数组元素的下标 
	printf("ret:%d  a[%d]:%d\n",ret,ret,a[ret]);
	return 0 ;
}

运行结果:


目录
相关文章
|
JavaScript 算法 前端开发
【前端算法】JS实现数字千分位格式化
JS实现数字千分位格式化的几种思路,以及它们之间的性能比较
337 1
|
存储 前端开发 算法
一行代码解决LeetCode实现 strStr()使用JavaScript解题|前端学算法
一行代码解决LeetCode实现 strStr()使用JavaScript解题|前端学算法
158 0
一行代码解决LeetCode实现 strStr()使用JavaScript解题|前端学算法
一则有趣的算法题:两个栈实现一个队列
一则有趣的算法题:两个栈实现一个队列
|
算法 计算机视觉 Python
Python实现KNN算法和交叉验证
Python实现KNN算法和交叉验证
339 0
Python实现KNN算法和交叉验证
|
算法 数据挖掘 Python
利用python实现Apriori关联规则算法
利用python实现Apriori关联规则算法
651 0
利用python实现Apriori关联规则算法
|
算法 Java Go
运筹优化学习21:Java调用Cplex实现求解Cuting Stock Porblem的列生成算法详解(下)
运筹优化学习21:Java调用Cplex实现求解Cuting Stock Porblem的列生成算法详解
运筹优化学习21:Java调用Cplex实现求解Cuting Stock Porblem的列生成算法详解(下)
|
算法 Java 决策智能
运筹优化学习21:Java调用Cplex实现求解Cuting Stock Porblem的列生成算法详解(中)
运筹优化学习21:Java调用Cplex实现求解Cuting Stock Porblem的列生成算法详解
运筹优化学习21:Java调用Cplex实现求解Cuting Stock Porblem的列生成算法详解(中)
|
算法 Java Go
运筹优化学习21:Java调用Cplex实现求解Cuting Stock Porblem的列生成算法详解(上)
运筹优化学习21:Java调用Cplex实现求解Cuting Stock Porblem的列生成算法详解
运筹优化学习21:Java调用Cplex实现求解Cuting Stock Porblem的列生成算法详解(上)
|
算法 决策智能 C++
运筹优化学习10:分支定界算法求解整数规划问题及其Matlab实现(下)
运筹优化学习10:分支定界算法求解整数规划问题及其Matlab实现
运筹优化学习10:分支定界算法求解整数规划问题及其Matlab实现(下)
|
算法 决策智能
运筹优化学习10:分支定界算法求解整数规划问题及其Matlab实现(上)
运筹优化学习10:分支定界算法求解整数规划问题及其Matlab实现
运筹优化学习10:分支定界算法求解整数规划问题及其Matlab实现(上)

热门文章

最新文章