概述
问题描述:
输入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
思考过程:
本题要求用三个函数解决问题,所以我认为应当有,找出最小,找出最大,交换着三个函数,找出最小这个函数,用一个指针定位最小,边遍历边找,遍历一次完,指针指向最小的,该函数返回最小的指针,然后调用交换函数,找最大同理。
代码展示:
#include<stdio.h>
void swap(int *a,int *b);
int * findmax(int *a);
int * findmin(int *a);
int main(void)
{
int a[10],i,*max,*min;
for(i=0;i<10;i++)
{
scanf("%d",&a[i]);
}
max=findmax(a);
swap(&a[9],max);
min=findmin(a);
swap(a,min);
for(i=0;i<10;i++)
{
printf("%d ",a[i]);
}
printf("n");
return 0;
}
void swap(int *a,int *b)
{
int tem;
tem=*a;
*a=*b;
*b=tem;
}
int* findmax(int *a)
{
int *max,i,max1=a[0];
for(i=0;i<10;i++)
{
if(max1<a[i])
{
max=&a[i];
max1=a[i];
}
}
return max;
}
int* findmin(int *a)
{
int *min,i,min1=a[0];
for(i=0;i<10;i++)
{
if(min1>a[i])
{
min=&a[i];
min1=a[i];
}
}
return min;
}
最后
以上就是健忘西装为你收集整理的C/C++快速入门->指针 问题 E: C语言10.16的全部内容,希望文章能够帮你解决C/C++快速入门->指针 问题 E: C语言10.16所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复