恕我直言,你编的这段程序错误百出,惨不忍睹!根据你编写的程序的意图和算法编写的相应程序如下:
//---------------------------------------------------------------------------
#include
int *my(int *a,int n)
{
int i,max,min;
static int b[2];
max=min=a[0];
for (i = 0; i
if(a[i]
return b;
}
void main()
{
int a[9]={1,2,3,4,5,6,7,8,9},*b;
b=my(a,9);
printf("输出的下标分别为%d,%d\n",b[0],b[1]);
}
//---------------------------------------------------------------------------
*******************************************************
*******************************************************
1.递归函数,返回最值位置,如果有多个相同的最值,将返回靠近结尾的。
//---------------------------------------------------------------------------
#include
void mo(int *a,const int n,int *max,int *min)
{
*max=a[n]>a[*max]?n:*max;
*min=a[n]>a[*min]?*min:n;
if (n) mo(a,n-1,max,min);
}
int main(void)
{
int max=0,min=0;
int a[9]={8,9,2,7,6,1,3,5,9};
mo(a,8,&max,&min);
return 0;
}
//---------------------------------------------------------------------------
2.非递归函数,返回最值位置,如果有多个相同的最值,将返回靠近开头位置的。
//---------------------------------------------------------------------------
#include
void mo(int *a,const int n,int *max,int *min)
{
int i;
*max=*min=0;
for (i = 0; i<=n; i++) {
*max=a[i]>a[*max]?i:*max;
*min=a[i] }
}
int main(void)
{
int max=0,min=0;
int a[9]={8,9,2,7,6,1,3,5,9};
mo(a,8,&max,&min);
return 0;
}
//---------------------------------------------------------------------------
一个参数保存下标,一个保存MAX一个MIN, 1个循环就可以搞定的.
MAX 和MIN初始化为a[0];
如果要复杂度简单点的,就a[n]和a[n+1]先比,大的和MAX比,小的和MIN比. for(..; ..; n+2);
int* myfuntion{
int sub[2];
int i;
int Max= 0 ,Min= 0;//
int temp1,temp2;//
for(i =0;i
if(a[i]
return sub[] = {temp1,temp2};
}
不能够返回两个值
只能写两个函数分别返回
1个函数不能反回两个值