美文网首页
4-13 折半查找

4-13 折半查找

作者: Muzi_Jin | 来源:发表于2017-04-21 16:24 被阅读0次

Attention: 如果喜欢我写的文章,欢迎来我的github主页给star
Githubgithub.com/MuziJin

给一个严格递增数列,函数int binSearch(SeqList T, KeyType k)用来二分地查找k在数列中的位置。

函数接口定义

int  binSearch(SeqList T, KeyType k);

其中T是有序表,k是查找的值。

裁判测试程序样例

#include <iostream>
using namespace std;

#define MAXLEN 50
typedef int KeyType;

typedef  struct                     
{ KeyType  key;                                             
} elementType;  

typedef  struct
{ elementType   data[MAXLEN+1]; 
  int   len;
} SeqList;                      

void creat(SeqList &L)
{ int i;
  cin>>L.len;
  for(i=1;i<=L.len;i++)
     cin>>L.data[i].key;   
}

int  binSearch(SeqList T, KeyType k);

int main () 
{  SeqList L;  KeyType k;
   creat(L);
   cin>>k;
   int pos=binSearch(L,k);
   if(pos==0) cout<<"NOT FOUND"<<endl;
   else cout<<pos<<endl;
   return 0;
}

/* 请在这里填写答案 */

输入格式

第一行输入一个整数n,表示有序表的元素个数,接下来一行n个数字,依次为表内元素值。 然后输入一个要查找的值。

输出格式

输出这个值在表内的位置,如果没有找到,输出"NOT FOUND"。

输入样例:

5
1 3 5 7 9
7

输出样例

4

输入样例:

5
1 3 5 7 9
10

输出样例

NOT FOUND

Code

int  binSearch(SeqList T, KeyType k)
{
    int i = 1;
    int j = T.len;
    int mid;
    int loc = 0;
    while( i<j)
    {
        mid = ( i+j)/2;
        if( T.data[mid].key == k)
        {
            loc = mid;
            break;
        }
        else if( T.data[mid].key > k)
            j = mid-1;
        else 
            i = mid+1;
    }
    return loc;
}

转载请注明出处:github.com/MuziJin

相关文章

  • 4-13 折半查找

    Attention: 如果喜欢我写的文章,欢迎来我的github主页给starGithub:github.com...

  • 4-13 折半查找

    [关于二分法查找]基本思想:假设数据是按升序排序的,对于给定值x,从序列的中间位置开始比较,如果当前位置值等于x,...

  • PHP查找算法

    静态查找 顺序查找 折半查找 递归折半查找

  • 算法(一)查找算法 平衡二叉树,红黑树,B树等

    顺序查找 略 折半查找 折半查找,也称二分查找,在某些情况下,折半查找比顺序查找效率更高(要求静态查找表中数据必须...

  • C语言折半查找

    折半查找 折半查找的注意点折半查找只能查找有序数组的值 折半查找的逻辑1.把数组第一个元素的索引作为最小值,最后一...

  • 查找算法

    1.顺序查找法 改进后的顺序查找法 2.折半查找法 3.插值查找 插值查找其实是折半查找的升级版,在我们写折半查找...

  • 重温数据结构_树表的查找

    线性表的查找的顺序查找和折半查找作为查找表的组织形式,其中折半查找效率较高。但由于折半查找要求表中记录按关键字有序...

  • 2018-08-27

    折半查找

  • 查找-折半查找

    给定一个有序序列,查找与key相等的值,如果没有则返回-1(注意这里不要返回0,会和数组下标重复)

  • 折半查找

网友评论

      本文标题:4-13 折半查找

      本文链接:https://www.haomeiwen.com/subject/wkwdzttx.html