#include<stdio.h>
int TWO(int arr[], int n, int sz)
{
int l = 0;
int r = sz - 1;
while (l <= r)
{
int mid = l + (r - l) / 2;
if (arr[mid] > n)
{
r = mid - 1;
}
else if (arr[mid] < n)
{
l = mid + 1;
}
else
{
return mid;
}
}
return -1;
}
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9 };
int n = 17;
int sz = sizeof(arr) / sizeof(arr[0]);
int ret = TWO(arr, n, sz);
if (TWO==-1)
{
printf("没找到!\n");
}
else
{
printf("找到了,下标是:%d\n", ret);;
}
return 0;
}
这个找不到的代码结果为什么不正确?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- micthis 2024-03-29 22:39关注
这也太粗心了,if(TWO==-1)?ret==-1
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 ansys fluent计算闪退
- ¥15 有关wireshark抓包的问题
- ¥15 需要写计算过程,不要写代码,求解答,数据都在图上
- ¥15 向数据表用newid方式插入GUID问题
- ¥15 multisim电路设计
- ¥20 用keil,写代码解决两个问题,用库函数
- ¥50 ID中开关量采样信号通道、以及程序流程的设计
- ¥15 U-Mamba/nnunetv2固定随机数种子
- ¥15 vba使用jmail发送邮件正文里面怎么加图片
- ¥15 vb6.0如何向数据库中添加自动生成的字段数据。