#include<stdio.h>
#define N 15
int main()
{
int a[N];
int mid,left=0,right=14,i;
int key;
for(i=0;i<N;i++)
{
scanf("%d",&a[i]);
}
scanf("%d",&key);
while(left<=right)
{
mid=(left+right)/2;
if(key<a[mid])//查找值在中间值的左侧
{
right=mid-1;//往左缩小区间
}
else if(key>a[mid])//查找值在中间值的右侧
{
left=mid+1;//往右缩小区间
}
else if(key==a[mid])//查找值等于中间值
{
printf("%d\n",mid);
break;//跳出循环
}
else if(left>right)
{
printf("NO\n");
break;
}
}
return 0;
}
//能帮我看看这程序该怎么改吗?谢谢您。我真的不知道该怎么弄了😭
给定15个按从小到大已经有序的整数,将其放在一个数组中。另外输入一个整数,要求使用折半查找法找出该数是数组中的第几个元素的值。如果该数不在数组中,则输出“NO”。
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 南七灵 2021-12-15 18:15关注
#include <stdio.h> #define N 15 int main() { int a[N]; int mid, left = 0, right = 14, i; int key; for (i = 0; i < N; i++) { scanf("%d", &a[i]); } scanf("%d", &key); while (left <= right) { mid = (left + right) / 2; if (key < a[mid]) //查找值在中间值的左侧 { right = mid - 1; //往左缩小区间 } else if (key > a[mid]) //查找值在中间值的右侧 { left = mid + 1; //往右缩小区间 } else if (key == a[mid]) //查找值等于中间值 { printf("%d\n", mid + 1); return 0; } } printf("NO\n"); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 2无用
悬赏问题
- ¥20 论文AlphaTensor复现(有偿)
- ¥15 (有偿)在ANSYS中 .anf文件
- ¥45 关于#芯片#的问题:组合逻辑电路设计
- ¥15 基与机器学习和时间序列分析预测养老服务需求趋势
- ¥100 求连续两帧图像在水平和垂直上偏移
- ¥15 mysql全文索引查找指定必须关键词word无效
- ¥15 Verilog hdl密码锁设计
- ¥35 基于python的有ssl加密传输的socket聊天室
- ¥15 数码管亮度控制器设计
- ¥15 kafka客户端跨网段访问,看日志提示连接的还剩内网地址,且访问不通