wojiaoqingfeng 2022-12-28 19:19 采纳率: 78.6%
浏览 10
已结题

找到中间位置mid查找mnid位置的值,如果成功返回其逻辑序号mid+1

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(查找失败)
}

  • 写回答

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;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 1月6日
  • 已采纳回答 12月29日
  • 创建了问题 12月28日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。