加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C++二分法在数组中查找关键字的方法

发布时间:2020-12-16 03:01:54 所属栏目:百科 来源:网络整理
导读:本篇章节讲解C++二分法在数组中查找关键字的方法。供大家参考研究。具体如下: /* 此程序演示了二分法查找算法(针对按从小到大排列的数组)的实现。*/#include iostreamusing namespace std;/* 功能: 实现数组的二分法查找(只算法只适合按从小到大排

本篇章节讲解C++二分法在数组中查找关键字的方法。分享给大家供大家参考。具体如下:

/*
  此程序演示了二分法查找算法(针对按从小到大排列的数组)的实现。
*/
#include <iostream>
using namespace std;
/*
  功能: 实现数组的二分法查找(只算法只适合按从小到大排列的数组)
  返回值:关键字在数组中的下标,返回-1表示未找到
  a[]:  要搜索的数组
  len:  数组元素个数
  key:  要查找的关键字
*/
int binSearch(int a[],int len,int key)
{
  int i = len / 2;
  int ii = 0;
  if(len < 1)
    return -1;
  if((key > a[i]) && (len - i > 0))
  {
    ii = binSearch(a+i+1,len - i - 1,key); // 在后半段数组中查找
    if(ii != -1)
      return ii + i + 1; // 加上数组前半段的长度
    else
      return -1;
  }
  else if(key < a[i] && i > 0) // 在前半段数组中查找
    return binSearch(a,i,key);
  else if(key == a[i])
    return i; // 返回关键字在数组中的下标
  else
    return -1; // 未在数组中找到关键字
}
int main()
{
  int a[] = {2,4,5,20,24,35,66,78,98};
  int len = sizeof(a) / sizeof(int);
  int i,key = -1;
  while(1)
  {
    cin>>key;
    i = binSearch(a,len,key);
    printf("%dn",i);
    if(key > 100)
      break;
  }
  return 0;
}

希望本文所述对大家的C++程序设计有所帮助。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读