利用减半递推技术,写出求长度为n的数组中最大元素的递归算法。设n=2点k次方,
以下的程序,n为非0任意自然数:
#include"stdio.h"
int max(int a[],int left,int right)
{int mid=(left+right)/2;
if(mid==left)return a[left]>a[right]?a[left]:a[right];
else return max(a,left,mid)>max(a,mid+1,right)?max(a,left,mid):max(a,mid+1,right);
}
int main()
{int i,a[12]={34,12,76,98,43,45,79,62,96,91,30,84};
for(i=0;i<12;i++)printf("%d ",a[i]);
printf("\nmax=%d\n",max(a,0,11));
return 0;
}
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。