当前位置: 代码迷 >> 综合 >> ZZULIOJ--1158: 又是排序(指针专题)
  详细解决方案

ZZULIOJ--1158: 又是排序(指针专题)

热度:64   发布时间:2023-12-06 06:04:33.0

1158: 又是排序(指针专题)

时间限制: 1 Sec  内存限制: 128 MB
提交: 6918  解决: 3203
[状态] [讨论版] [提交] [命题人:admin]
题目描述
将输入的四个整数按由大到小的顺序输出。
请你定义一个四个数排序的函数psort,psort的四个参数为要排序的四个整数变量的地址,请你按照从大到小的顺序把四个数分别放到四个指针所指向的变量里,不要在函数内输入输出任何内容。请务必使用函数实现四个数的排序。
void psort( int *pa, int *pb,int *pc,int *pd)
{
    //实现四个数的排序,并分别放到四个指针所指向的变量里。
}


 

注意:本题如果采用C/C++提交时,至少要编写psort()函数和main()函数两个函数,并提交完整的程序代码。

输入
输入4个整数,用空格隔开。
输出
输出排序后的4个整数,由空格隔开。输出占一行。
样例输入 Copy
4 3 5 2
样例输出 Copy
5 4 3 2

代码 

#include <stdio.h>
#include <string.h>
void psort( int *pa, int *pb,int *pc,int *pd);
int main()
{int a,b,c,d;scanf("%d%d%d%d",&a,&b,&c,&d);//输入4个数psort(&a,&b,&c,&d);//将四个数放入指针return 0;
}
void psort( int *pa, int *pb,int *pc,int *pd)
{int i,j,t,a[5];//将指针的值放入数组a[0]=*pa;a[1]=*pb;a[2]=*pc;a[3]=*pd;a[4]='\0';for(i=0;i<4;i++)for(j=i+1;j<4;j++)//排序数组{if(a[i]>a[j]){t=a[i];a[i]=a[j];a[j]=t;}}for(i=3;i>=0;i--)//输出数组{if(i==3)printf("%d",a[i]);elseprintf(" %d",a[i]);}}

  相关解决方案