5、补充BEGIN-END之间的内容,完成折半查找算法
#include <stdio.h>
typedef int KeyType; //定义关键字类型为int
typedef char InfoType;
typedef struct
{ KeyType key; //关键字项
InfoType data; //其他数据项,类型为InfoType
} RecType; //查找元素的类型
int BinSearch(RecType R[],int n,KeyType k) //折半查找算法
{ int low=0,high=n-1,mid;
while (low<=high) //当前区间存在元素时循环
{
/**********BEGIN**********/
/*
找到中间位置mid
查找mid位置的值,如果成功返回其逻辑序号mid+1
如果小于mid位置的值,继续在R[low..mid-1]中查找
如果大于mid位置的值,继续在R[mid+1..high]中查找
*/
/**********END**********/
}
return 0; //未找到时返回0(查找失败)
}
找到中间位置mid查找mnid位置的值,如果成功返回其逻辑序号mid+1
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- 流比 2022-12-28 19:36关注
mid = (low + high) / 2; if (R[mid].key == k) { return mid + 1; } else if (R[mid].key > k) { high = mid - 1; } else { low = mid + 1; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 winform的chart曲线生成时有凸起
- ¥15 msix packaging tool打包问题
- ¥15 finalshell节点的搭建代码和那个端口代码教程
- ¥15 用hfss做微带贴片阵列天线的时候分析设置有问题
- ¥15 Centos / PETSc / PETGEM
- ¥15 centos7.9 IPv6端口telnet和端口监控问题
- ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
- ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
- ¥20 海浪数据 南海地区海况数据,波浪数据
- ¥20 软件测试决策法疑问求解答