引用做形参(给三个数排序)

本文通过两个函数实现对整型变量的排序操作,分别采用引用传递和指针传递的方式修改外部变量。函数内部使用了简单的冒泡排序算法来确保传入的三个整数按递增顺序排列。通过这种方式,演示了不同参数传递方式对函数内部操作的影响。
#include <iostream>
using namespace std;
void fun1(int &x,int &y,int &z);
void fun2(int *x,int *y,int *z);
int main()
{
    int a,b,c;
    cin>>a>>b>>c;
    fun1(a,b,c);
    cout<<a<<" "<<b<<" "<<c<<endl;
    fun2(&a,&b,&c);
    cout<<a<<" "<<b<<" "<<c<<endl;
    return 0;
}
void fun1(int &x,int &y,int &z)
{
    int t;
    if(x<y)
    {
        t=x;
        x=y;
        y=t;
    }
    if(x<z)
    {
        t=x;
        x=y;
        y=t;
    }
    if(y<z)
    {
        t=y;
        y=z;
        z=t;
    }
}
void fun2(int *x,int *y,int *z)
{
    int t;
    if(*x<*y)
    {
        t=*x;
        *x=*y;
        *y=t;
    }
    if(*x<*z)
    {
        t=*x;
        *x=*z;
        *z=t;
    }
    if(*y<*z)
    {
        t=*y;
        *y=*z;
        *z=t;
    }
}

输出结果:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值