请问这个问题错在哪里了!
/*输入10个整数,将其中最小的数与第一个互换!把最大数与最后一个数对换.写三个函数(1)输入十个数,(2)进行处理,(3)输出十个数*/
#include<stdio.h>
main( )
{
int arry[10];
printf("qing shuru shige shu...\n");
scan(arry,10);
chuli(arry,10);
print(arry,10);
getch( );
return 0;
}
scan(int a[ ],int n)
{
int i=0;
for(;i<n;i++)
scanf("%d",&a[i]);
return 0;
}
chuli(int *p,int n)
{
int i=0,max,min,temp_1,temp_2,x,y;
int *point; /*用point记录数组的首地址*/
point=p;
max=min=0;
for(;i<n;i++)
{
if(max<*(p+i))
max=*(p+i);
x=i; /*求最大值是第几个数*/
if(min>*(p+i))
min=*(p+i);
y=i; /*求最小值是第几人数*/
}
p=point;
temp_1=*(p+x);
*(p+x)=*(p+n-1);
*(p+n-1)=temp_1; /*将最大值和最后一个数互换*/
p=point;
temp_2=*(p+y);
*(p+y)=*p;
*p=temp_2;
teturn 0;
}
print(int *p2,int n)
{
int i=0;
for(;i<n;i++,p2++)
printf("%4d",*p2);
return 0;
}
这个是书上的一个习题!我做了半天!好不容易编译通过了!可是在运行的时候又来问题!
就如果输入的数组是从大到小排列的时候这个可以实现题目的要求!
可是如果最大数在中间的话就不行了!
请高手来看看吧!
实在是想不起来了