一、题目描述
输入三个整数,然后按照从大到小的顺序输出数值。
要求:用三个指针分别指向这三个整数,排序过程必须通过这三个指针来操作,不能直接访问这三个整数
输出时,必须使用这三个指针,不能使用存储三个整数的变量
二、输入与输出
1.输入
第一行输入t表示有t个测试实例
第二行起,每行输入三个整数
输入t行
3
2 4 6
88 99 77
111 333 222
2.输出
每行按照从大到小的顺序输出每个实例
6 4 2
99 88 77
333 222 111
三、参考代码
#include<iostream>
#include <iomanip>
using namespace std;
void swap(int *a,int*b)
{
int t=*a;
*a=*b;
*b=t;
}
void sort(int*num1,int *num2,int*num3)
{
if(*num1<*num2) swap(num1,num2);
if(*num1<*num3) swap(num1,num3);
if(*num2<*num3) swap(num2,num3);
}
int main()
{
int *a,*b,*c;
int num1,num2,num3;
int t;
cin>>t;
while(t--)
{
cin>>num1>>num2>>num3;
a=&num1;
b=&num2;
c=&num3;
sort(a,b,c);
cout<<*a<<" "<<*b<<" "<<*c<<endl;
}
}
四、题解思路
由于只有三个数比较大小,所以可以采用一个比一个的方法。
利用sort函数(传递数值)和swap函数(交换数值)来实现,最后再输出。