jcfeng

关于C语言二分法

二分法

适应情况:在一批有序数据中查找某数,在实际的应用中还会运用到冒泡法的排序方法

基本思想:选定这批数中居中间位置的一个数与所查数比较,看是否为所找之数,若不是,利用数据的有序性,可以决定所找的数是在选定数之前还是在之后,从而很快可以将查找范围缩小一半。以同样的方法在选定的区域中进行查找,每次都会将查找范围缩小一半,从而较快地找到目的数。

 

例题:假设在数组a中的数据是按由小到大顺序排序的:-12 0 6 16 23 56 80 100 110 115,从键盘上输入一个数,判定该数是否在数组中,若在,输出所在序号。

#define M 10
#include <stdio.h>
int main(){
  int a[M]={-12,0,6,16,23,56,80,100,110,115};
  int low,mid,high,b,found;
  low=0;
  high=M-1;
  scanf("%d",&b);
  while(low <= high){
    mid=(low+high)/2;
    if(b == a[mid]){
      found =1;
      break;
    }else if(b>a[mid]){
      low=mid+1;
    }else{
      high=mid-1;
    }
  }
  if(found ==1){
    printf("The index of %d is %d",b,mid);
  }else{
    printf("There is not %d",b);
  }
  return 0;
}

 

发表于 2019-08-05 16:32  一点小经验  阅读(3116)  评论(0编辑  收藏  举报
 

分类:

技术点:

相关文章:

  • 2022-12-23
  • 2022-01-18
  • 2022-12-23
  • 2022-12-23
  • 2021-09-15
  • 2021-12-03
  • 2021-12-03
猜你喜欢
  • 2021-12-03
  • 2021-12-09
  • 2021-09-22
  • 2021-12-03
  • 2022-12-23
  • 2022-12-23
  • 2021-11-28
相关资源
相似解决方案