为了账号安全,请及时绑定邮箱和手机立即绑定

c语言的一个问题

c语言的一个问题

蓝山帝景 2019-03-30 11:31:07
设计并编写一个C语言函数unsignedcharisldentical(inta[],unsignedintn),判断给定的长度为n的元素各不相同且已按升序排序的数组a中是否存在一个元素等于其索引值,即a[i]=i,如果存在返回1,否则返回0。要求算法的时间复杂度为O(logn)。
查看完整描述

2 回答

?
30秒到达战场

TA贡献1828条经验 获得超6个赞

正如楼上说的
伪代码如下,
isldentical用去掉另外一个函数,占且定为isldenticalfun,需要知道开始,结束为位置
isldenticalfun(a[],0,n):
ifa[n/2]>n/2://说明在你只可能去左边找了
returnisldenticalfun(a,0,n/2-1)
elseifa[n/2]returnisldenticalfun(a,n/2+1,n)
else://说明找到了
returnn/2
                            
查看完整回答
反对 回复 2019-03-30
?
ibeautiful

TA贡献1993条经验 获得超5个赞

二分法好像可以搞定
                            
查看完整回答
反对 回复 2019-03-30
  • 2 回答
  • 0 关注
  • 404 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信