zoukankan      html  css  js  c++  java
  • C/C++ 交换两个数,不使用第三个变量, 函数模板来实现

    #include <iostream>
    
    template<typename T>
    void exchangeTwoNumber(T &t1, T &t2);

    void test();
    int main() { int a = 10, b = 20; double q = 10.1, w = 20.2; char z = 'z', x = 'x'; std::cout << "交换前的 a = " << a << ", b = " << b << std::endl; std::cout << "交换前的 q = " << q << ", w = " << w << std::endl; std::cout << "交换前的 z = " << z << ", x = " << x << std::endl; exchangeTwoNumber(a, b); exchangeTwoNumber(q, w); exchangeTwoNumber(z, x); test(); std::cout << std::endl; std::cout << std::endl; std::cout << "交换后的 a = " << a << ", b = " << b << std::endl; std::cout << "交换后的 q = " << q << ", w = " << w << std::endl; std::cout << "交换后的 z = " << z << ", z = " << x << std::endl; } template<typename T> void exchangeTwoNumber(T &t1, T &t2) //通用的函数模板 { t1 = t1 + t2; t2 = t1 - t2; t1 = t1 - t2; } void test() //异或的方式,变形成函数模板,编译不通过 { int a = 1, b = 2; a ^= b; b ^= a; a ^= b; std::cout << "...a=" << a << ", b=" << b << std::endl; }
  • 相关阅读:
    模版
    列表项模版
    vue eventBus 跳坑的办法
    vue适配移动端px自动转化为rem
    pc端,移动端css重置样式
    vue全局引入scss文件(推荐)
    vue安装scss,并且全局引入
    mapState
    通俗易懂的vuex-demo
    ve2.0 v-for循环报错的解决方案
  • 原文地址:https://www.cnblogs.com/azbane/p/11261698.html
Copyright © 2011-2022 走看看