牛骨文教育服务平台(让学习变的简单)
博文笔记
  • 当前位置:
  • 牛骨文教育服务平台
  • >
  • 博文笔记
  • >
  • 有15个数按由大到小顺序存放在一个数组中,输入一个数,要求用折半查找法找出该数是数组中第几个元素的值。如果该数不在数组中,则输出“无此数”

有15个数按由大到小顺序存放在一个数组中,输入一个数,要求用折半查找法找出该数是数组中第几个元素的值。如果该数不在数组中,则输出“无此数”

创建时间:2018-01-29 投稿人: 浏览次数:145
#include <stdio.h>
#include <conio.h>
int main(){
  int a[7]={1,2,3,4,5,6,7};
  int i,num,n,low,high,mid;
  printf("数组为: ");
  for(i=0;i<7;i++)
    printf("%3d",a[i]);
  printf(" 请输入数组中的一个数:");
  scanf("%d",&num);
  n=7;
  low=0;
  high=n-1;
  while(low<=high){
    mid=(low+high)/2;
    if(num<a[mid])
      high=mid-1;
    else if(num>a[mid])
      low=mid+1;
    else if(num==a[mid]){
      printf("%d是数组中第%d个元素的值",num,mid+1);
      break;
    }
  }
  if(num!=a[mid])
    printf("无此数");
  getch();
  return 0;


声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。