int fun(int a[], int length, int result) {
int first = 0, last = length - 1;
int middle = 0;
while (first <= last) {
middle = (first + last) >> 1;
if (a[middle] == result) {
return middle;
} else if (a[middle] > result) {
last = middle - 1;
} else {
first = middle + 1;
}
}
return -1;
}
这段代码什么意思呢
这段代码怎样写成递归的啊
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- vyyv00 2017-03-30 14:48关注
: 右移运算符,num >> 1,相当于num除以2
这段代码是在长度为length的数组a[]中寻找数字result所在的位置,如未找到返回-1;
例: a[]={3,6,7,9,12,5}; length=6; rusult=7
return 3本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 找一个QT页面+目标识别(行人检测)的开源项目
- ¥15 有没有整苹果智能分拣线上图像数据
- ¥20 有没有人会这个东西的
- ¥15 cfx考虑调整“enforce system memory limit”参数的设置
- ¥30 航迹分离,航迹增强,误差分析
- ¥15 Chrome Manifest扩展引用Ajax-hook库拦截请求失败
- ¥15 用Ros中的Topic通讯方式控制小乌龟的速度,走矩形;编写订阅器代码
- ¥15 LLM accuracy检测
- ¥15 pycharm添加远程解释器报错
- ¥15 如何让子窗口鼠标滚动独立,不要传递消息给主窗口