c语言对非递减序列进行查找,对非递减整数序列进行折半查找、C语言

满意答案

00e27ab806e4881f8254fe7ae8741834.png

yingdie0053

2014.02.03

00e27ab806e4881f8254fe7ae8741834.png

采纳率:44%    等级:12

已帮助:6620人

#include "stdio.h"

int cishu=0;

int compare(int x,int y)

{

cishu++;

if(x

else if(x==y) return 0;

else return 1;

}

int binary(int a[],int left,int right,int search)

{ int middle;

while(left<=right)

{ middle=(left+right)/2;

switch(compare(search,a[middle]))

{ case -1:right=middle-1; break;

case 0: return middle;

case 1:left=middle+1; }

}

return -1;

}

int main()

{ int a[12]={0,1,2,3,4,5,6,7,8,9,10,11};

int left,right,search,n,i;

printf("the data is :\n");

for(i=0;i<12;i++)

printf("%d ",a[i]);

printf("\nenter you want look number:\n");

scanf("%d",&search);

left=0; right=11;

n=binary(a,left,right,search);

if(n!=-1) printf("the location is %d\n",n);

else printf("the number is not found.\n");

printf("关键字比较的次数:%d\n",cishu);

}

如上,在一楼基础上加个全局变量cishu,表示关键字比较的次数。

例如:

0,1,2,3,4,5,6,7,8,9,10,11

你要查找6.

初始left=0,right=11.

这时候关键字比较是

6和a[5],5=(0+11)/2;

也就是6和5比较

6比5大,所以left=5;

然后在关键字比较

6和a[8],8=(5+11)/2;

也就是6和7比较。

6比7小。

所以right=7;

然后在关键字比较

6和a[6],6=(5+70/2;

这时候a和a[6]相等,找到。

所以就进行了3次关键字比较。

00分享举报

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值