摘要:本文主要向大家介绍了C/C++知识点之C语言二分查找,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。
本文主要向大家介绍了C/C++知识点之C语言二分查找,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。
#include
/*
二分查找条件: 1、有序序列 2、数据在数组中
*/
int baseBinarySearch(int a[],int h,int k)
{
int low=0;
int high=h;
int mid =0;
int NoFound = -1;
while (low <= high)
{
mid = low + (high-low) /2 ;
if ( k < a[mid] )
{
high = mid - 1;
}
else if ( k > a[mid] )
{
low = mid + 1;
}
else
{
return mid;
}
}
return NoFound;
}
//查找第一个相等的元素
int FirstElementBinSearch(int a[],int h,int k)
{
int low=0;
int high=h;
int mid =0;
int NoFound = -1;
while (low <= high)
{
mid = low + (high-low) /2 ;
if ( k <= a[mid] )
{
high = mid - 1;
}
else
{
low = mid + 1;
}
}
return low <= h ? low : NoFound;
}
//查找最后一个相等的元素low
int LastElementBinSearch(int a[],int h,int k)
{
int low=0;
int high=h;
int mid =0;
int NoFound = -1;
while (low <= high)
{
mid = low + (high-low) /2 ;
if ( k >= a[mid] )
{
low = mid + 1 ;
}
else
{
high = mid -1 ;
}
}
printf("%d %d %d\n",low,high,a[low-1]);
if (low - 1 >= 0 && a[low - 1] ==k)
{
return low-1;
}
return NoFound;
}
本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标编程语言C/C+频道!
您输入的评论内容中包含违禁敏感词
我知道了
请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号