题目描述
输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。要求用3个函数实现,分别为输入10个数、进行处理、输出10个数。要求使用指针的方法进行处理。
输入
用空格隔开的10个整数。
输出
输出进行题目描述操作之后的10个整数,每个整数之后输出一个空格。
请注意行尾输出换行。
样例输入 Copy
1 5 2 4 9 0 3 8 7 6
样例输出 Copy
0 5 2 4 6 1 3 8 7 9
#include <stdio.h>
void input(int x[],int* p[])
{
for(int i=0;i<10;i++)
{
scanf("%d",&x[i]);
p[i]=&x[i];
}
}
void change(int x[],int* p[])
{
int* temp=p[0];
int maxi=0,mini=0;
for(int i=0;i<10;i++) //不要在循环内交换,应该先判断出最大值和最小值的索引
{
if(x[mini]>x[i])
mini=i;
if(x[maxi]<x[i])
maxi=i;
}
temp=p[0]; //最好交换指针,如果直接取地址&x[maxi],会出错
p[0]=p[mini]; //因为有可能x[maxi]已经修改过;
p[mini]=temp;
temp=p[9];
p[9]=p[maxi];
p[maxi]=temp;
}
void output(int* p[])
{
for(int i=0;i<10;i++)
printf("%d ",*p[i]);
}
int main()
{
int a[50];
int* p[50];
input(a,p);
change(a,p);
output(p);
return 0;
}