题目描述
输入三个整数,然后按照从大到小的顺序输出数值。
要求:用三个指针分别指向这三个整数,排序过程必须通过这三个指针来操作,不能直接访问这三个整数
输出时,必须使用这三个指针,不能使用存储三个整数的变量
输入
第一行输入t表示有t个测试实例
第二行起,每行输入三个整数
输入t行
输出
每行按照从大到小的顺序输出每个实例
样例查看模式
正常显示查看格式
输入样例1
3
2 4 6
88 99 77
111 333 222
输出样例1
6 4 2
99 88 77
333 222 111
#include <iostream>
using namespace std;
void swap(int* n, int* m)
{
int o = *n;
*n = *m;
*m = o;
}
void sort(int* x, int* y, int* z)//x接收x(&a);int * x -->* (&a)
{
//(*x < *y) || ||a值<b值
//swap(x, y) || 这里的x y 也是地址
if (*x < *y)swap(x, y);
if (*x < *z)swap(x, z);
if (*y < *z)swap(z, y);
}
int main()
{
int t, i, a, b, c;
int* x, * y, * z;
cin >> t;
for (i = 0; i < t; i++)
{
cin >> a >> b >> c;
x = &a;
y = &b;
z = &c;
sort(x, y, z);//这里xyz 都是地址(&a &b &c) ;此处是把地址传过去
cout << *x << ' ' << *y << ' ' << *z << endl;
}
return 0;
}
本题主要理解:自定义函数带有指针的情况下 传给函数的是地址(带有&符号),函数接收是 x去接收(&a),而不是* p接收
x接收x(&a);int * x -->* (&a)