问题 E: C语言10.16
时间限制: 1 Sec 内存限制: 32 MB
题目描述
输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。要求用3个函数实现,分别为输入10个数、进行处理、输出10个数。要求使用指针的方法进行处理。
输入
用空格隔开的10个整数。
输出
输出进行题目描述操作之后的10个整数,每个整数之后输出一个空格。
请注意行尾输出换行。
样例输入
1 5 2 4 9 0 3 8 7 6
样例输出
0 5 2 4 6 1 3 8 7 9
经验总结
emmm,按照题目的意思来就行啦~
AC代码
#include <cstdio>
#include <cstring>
int* Return_Max_Location(int a[])
{
int max=0;
for(int i=1;i<10;i++)
if(a[max]<a[i])
max=i;
return &a[max];
}
int* Return_Min_Location(int a[])
{
int min=0;
for(int i=1;i<10;i++)
if(a[min]>a[i])
min=i;
return &a[min];
}
void Swap(int *a,int *b)
{
int temp=*a;
*a=*b;
*b=temp;
}
int main()
{
int a[10];
for(int i=0;i<10;i++)
scanf("%d",&a[i]);
int *p,*q;
p=Return_Max_Location(a);
Swap(p,&a[9]);
q=Return_Min_Location(a);
Swap(q,&a[0]);
for(int i=0;i<10;i++)
printf("%d ",a[i]);
return 0;
}