15个数按从小到大的顺序放在一个数组中,输入一个数,用折半查找法找出该数是数组中第几个元素的值?

该数不再数组中,则输出“无此数”... 该数不再数组中,则输出“无此数” 展开
 我来答
ch565097933
推荐于2019-08-10 · TA获得超过1044个赞
知道小有建树答主
回答量:825
采纳率:0%
帮助的人:515万
展开全部
C#:
public string GetIndex(int[] IntArray, int num)//数组和要找的数字
{
string ShowIndex = "";
int n = IntArray.Length;
int leftindex = 0;
int rightindex = n - 1;
int middleindex = (n - 1) / 2;
int find = 0;
while (leftindex <= rightindex)
{
middleindex = (leftindex + rightindex) / 2;
if (num == IntArray[middleindex])
{ ShowIndex = "数组第" + (middleindex + 1) + "个元素为" + num; find = 1; break; }
else if (num < IntArray[middleindex]) { rightindex = middleindex - 1; }
else { leftindex = middleindex + 1; }
}
if (find == 0)
ShowIndex = "无此数";
return ShowIndex;
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式