我是靠谱客的博主 飘逸身影,最近开发中收集的这篇文章主要介绍Contest100000571 - 《算法笔记》2.7小节——问题 E: C语言10.16,觉得挺不错的,现在分享给大家,希望可以做个参考。
概述
问题 E: C语言10.16
题目描述
输入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
提示:
注意运算符的优先级,笔者因为没注意Debug了好长时间。
参考代码:
#include<stdio.h>
#include<stdlib.h>
void creatTen(int *p)
{
int i;
for(i = 0; i < 10; i++)
{
scanf("%d", p+i);
}
}
void dealTen(int *p)
{
int i, temp1 = *p, flag1 = 0;
int j, temp2 = *p, flag2 = 0;
for(i = 0; i < 10; i++)
{
if(*(p+i) < temp1)
{
temp1 = (*(p + i));
flag1 = i;
}
if(*(p+i) > temp2)
{
temp2 = (*(p + i));
flag2 = i;
}
}
(*(p+flag1)) = *p;
*p = temp1;
*(p+flag2) = (*(p+9));
*(p+9) = temp2;
}
void printTen(int *p)
{
int i;
for(i = 0; i < 10; i++)
{
printf("%d ", *(p+i));
}
printf("n");
}
int main()
{
int * p = (int *)malloc(sizeof(int)*10);
creatTen(p);
dealTen(p);
printTen(p);
free(p);
return 0;
}
最后
以上就是飘逸身影为你收集整理的Contest100000571 - 《算法笔记》2.7小节——问题 E: C语言10.16的全部内容,希望文章能够帮你解决Contest100000571 - 《算法笔记》2.7小节——问题 E: C语言10.16所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复