#include<stdio.h>
#include<string.h>
void Max_Min(int a[],int st,int ed,int *Max,int *Min)
{
if(ed<=st+1)
{
if(a[st]>=a[ed])
{
*Max=a[st];
*Min=a[ed];
}
else
{
*Max=a[ed];
*Min=a[st];
}
return;
}
int LMin,LMax,RMin,RMax;
Max_Min(a,st,st+(ed-st)/2,&LMax,&LMin);
Max_Min(a,st+(ed-st)/2+1,ed,&RMax,&RMin);
if(LMin>RMin)
*Min=RMin;
else *Min=LMin;
if(LMax>RMax)
*Max=LMax;
else *Max=RMax;
}
int main()
{
int a[9]={11,22,1,-1,3,90,1009,78,43};
int Max,Min;
Max_Min(a,0,8,&Max,&Min);
printf("Max = %d Min = %d\n",Max,Min);
return 0;
}
C語言查找最大值和最小值遞歸實現
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.