zoukankan      html  css  js  c++  java
  • 两个数字交换的四种方法

    对于两种变量的交换,我发现四种方法,下面我用Java来演示一下。

    1.利用第三个变量交换数值,简单的方法。

    class TestEV

    //创建一个类

    {

        public static void main(String[]args)

        {

            int x =5,y=10; //定义两个变量

             

            int temp = x;    //定义第三临时变量temp并提取x值

            x = y;        //把y的值赋给x

            y = temp;      //然后把临时变量temp值赋给y

            

            System.out.println("x="+x+"y="+y);

            

        }

        

    }

     

    2.可以用两个数求和然后相减的方式进行数据交换,弊端在于如果 x 和 y 的数值过大的话,超出 int 的值会损失精度。

    class TestEV
    //创建一个类
    {
        public static void main(String[]args)
        {
            int x =5,y=10; //定义两个变量
            
            x = x + y;        //x(15) = 5 + 10;
            y = x - y;        //y(5) = x(15) - 10;        
            x = x - y;        //x(10) = x(15) - y(5)
            System.out.println("x="+x+"y="+y);
            
        }
        
    }
     

     3.利用位运算的方式进行数据的交换,利用的思想原理是:一个数异或同一个数两次,结果还是那个数,而且不会超出int范围

     

    class TestEV

    //创建一个类

    {

        public static void main(String[]args)

        {

            int x =5,y=10; //定义两个变量

            

            x = x^y;

            y = x^y;  //y=(x^y)^y

            x = x^y;  //x=(x^y)^x

            System.out.println("x="+x+"y="+y);

            

        }

        

     

      

    4.最为简单的,在打印输出的时候直接交换变量

    class TestEV

    //创建一个类

    {

        public static void main(String[]args)

        {

            int x =5,y=10; //定义两个变量

            

            System.out.println("x="+y+"y="+x); //直接在输出的时候交换

            

        }

        

    }





  • 相关阅读:
    EF6 Code First 模式更新数据库架构
    bootstrap-datepicker 插件修改为默认中文
    常用网络资源下载
    jQuery框架学习第十一天:实战jQuery表单验证及jQuery自动完成提示插件
    AngularJS实现原理
    [个人翻译]GitHub指导文件(GitHub Guides[Hello World])
    年后跳槽如何准备?
    前端学数据库之子查询
    Ionic实战 自动升级APP(Android版)
    读书笔记:《HTML5开发手册》Web表单
  • 原文地址:https://www.cnblogs.com/phonecom/p/8e97862eb0cf307753cf59ad4d9c0df3.html
Copyright © 2011-2022 走看看