<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆 - 312, 文章 - 14, 評(píng)論 - 1393, 引用 - 0
    數(shù)據(jù)加載中……

    不使用中間變量交換兩個(gè)數(shù)(Java版)

    本文為原創(chuàng),如需轉(zhuǎn)載,請(qǐng)注明作者和出處,謝謝!

        在程序中實(shí)現(xiàn)交換兩個(gè)數(shù)的功能并不復(fù)雜,但如果不使用中間變量,就需要?jiǎng)右幌履X筋。在本文介紹了兩個(gè)方法(其實(shí)原理都是一個(gè))。其基本原理就是數(shù)的中和。也就是說,通過某種運(yùn)算(二元運(yùn)算)將a和b兩個(gè)數(shù)變成一個(gè)數(shù),并保存在其中一個(gè)變量中。然后再通過同樣的運(yùn)算符將a或b中和掉。這樣實(shí)際上是利用了a或b本身作為了中間變量。
        先看第一個(gè)算法。
    static class Num
    {
        
    int a;
        
    int b;
    }
    public static void swap1(Num num)
    {

        num.a 
    = num.a + num.b;
        num.b 
    = num.a - num.b;
        num.a 
    = num.a - num.b;
    }

        上面代碼通過“+”運(yùn)算符將a和b的運(yùn)算結(jié)果賦給了a(這時(shí)a是中間變量)。然后再計(jì)算b,這時(shí)a的值已經(jīng)是(a+b)了,因此,a再減b就是原來的a。 而這時(shí)b已經(jīng)是原來的a了,因此,再用運(yùn)算后的a(實(shí)際上是a+b)減運(yùn)算后的b(實(shí)際上是原來的a),就是原來的b了,最后將這個(gè)b賦值給a。
        實(shí)際上,我們還可以使用“*”、“/”等符號(hào)來實(shí)現(xiàn)同樣的效果,代碼如下:
    public static void swap2(Num num)
    {
        num.a 
    = num.a * num.b;
        num.b 
    = num.a / num.b;
        num.a 
    = num.a / num.b;
    }
    public static void swap3(Num num)
    {
        num.a 
    = num.a - num.b;
        num.b 
    = num.a + num.b;
        num.a 
    = num.b - num.a;
    }
        上面代碼在Java中沒有什么問題(但使用“/”時(shí),分母和分子不能為0)。就算溢出也會(huì)得到正確的結(jié)果,但有某些語言中(如C語言),可能會(huì)拋出溢出錯(cuò)誤,不了避免這種錯(cuò)誤。可以加判斷,代碼如下:
    public static void swap4(Num num)
    {
        
    // 不同符號(hào)
        if (num.a * num.b <= 0)
        {
            num.a 
    = num.a + num.b;
            num.b 
    = num.a - num.b;
            num.a 
    = num.a - num.b;
        }
        
    else
        {

            num.a 
    = num.a - num.b;
            num.b 
    = num.a + num.b;
            num.a 
    = num.b - num.a;
        }
    }
        當(dāng)然,我們還有更好的方法,就是使用異或運(yùn)算符,我們知道,任何數(shù)與0異或后仍然為它本身,兩個(gè)相同的數(shù)異或后為0。根本這種特性,可以有如下代碼。

    public static void swap5(Num num)
    {
        num.a 
    = num.a ^ num.b;
        num.b 
    = num.a ^ num.b;
        num.a 
    = num.a ^ num.b;
    }





    Android開發(fā)完全講義(第2版)(本書版權(quán)已輸出到臺(tái)灣)

    http://product.dangdang.com/product.aspx?product_id=22741502



    Android高薪之路:Android程序員面試寶典 http://book.360buy.com/10970314.html


    新浪微博:http://t.sina.com.cn/androidguy   昵稱:李寧_Lining

    posted on 2010-07-28 10:29 銀河使者 閱讀(2797) 評(píng)論(8)  編輯  收藏 所屬分類: javaalgorithm 原創(chuàng)

    評(píng)論

    # re: 不使用中間變量交換兩個(gè)數(shù)(Java版)  回復(fù)  更多評(píng)論   

    num.a = num.a + num.b;
    溢出后就不對(duì)了吧,整數(shù)范圍很小的哦.
    2010-07-28 14:55 | 文溫

    # re: 不使用中間變量交換兩個(gè)數(shù)(Java版)  回復(fù)  更多評(píng)論   

    @文溫
    我試了,Java程序沒問題的。
    2010-07-28 17:08 | 銀河使者

    # re: 不使用中間變量交換兩個(gè)數(shù)(Java版)  回復(fù)  更多評(píng)論   

    加法 溢出后變成了 負(fù)數(shù),結(jié)果還對(duì).
    2147483647
    num.a = num.a * num.b;
    這個(gè)我試了一下 ,確實(shí)不行,
    2010-07-28 17:45 | 文溫

    # re: 不使用中間變量交換兩個(gè)數(shù)(Java版)  回復(fù)  更多評(píng)論   

    @文溫
    我說的就是加法,乘法不行。
    2010-07-28 18:20 | 銀河使者

    # re: 不使用中間變量交換兩個(gè)數(shù)(Java版)  回復(fù)  更多評(píng)論   

    意義在哪里?
    2010-07-28 22:59 | 隔葉黃鶯

    # re: 不使用中間變量交換兩個(gè)數(shù)(Java版)  回復(fù)  更多評(píng)論   

    少用了一個(gè)變量,節(jié)約內(nèi)存@隔葉黃鶯
    2010-07-29 20:29 | 低調(diào)打醬油

    # re: 不使用中間變量交換兩個(gè)數(shù)(Java版)  回復(fù)  更多評(píng)論   

    好文章 。我轉(zhuǎn)載了。。
    2010-07-30 15:34 | JUNV

    # re: 不使用中間變量交換兩個(gè)數(shù)(Java版)  回復(fù)  更多評(píng)論   

    a = (a+b)-(b=a);
    2010-08-03 13:50 | rk37
    主站蜘蛛池模板: 亚洲AV无码专区在线厂| 欧洲精品免费一区二区三区| 污污视频免费观看网站| 亚洲av永久无码嘿嘿嘿| 亚洲人成网站在线播放影院在线| 国产精品va无码免费麻豆| 久久受www免费人成_看片中文| 免费一区二区无码东京热| 亚洲视频在线一区二区| 精品熟女少妇AV免费观看| 91精品免费不卡在线观看| 亚洲av无码一区二区三区观看| 亚洲AV永久无码精品| 久久激情亚洲精品无码?V| **aaaaa毛片免费| 在线看片免费人成视频播| 国产精品hd免费观看| 狠狠热精品免费观看| 亚洲AV成人精品日韩一区| 亚洲乱码在线观看| 2020国产精品亚洲综合网| 亚洲国产日韩在线| 亚洲午夜精品第一区二区8050| 日本免费一区二区三区最新| 国产做国产爱免费视频| 国产成人高清精品免费观看| 免费人成动漫在线播放r18| 激情婷婷成人亚洲综合| 亚洲精品蜜夜内射| 亚洲人成网站18禁止| 亚洲欧美日韩中文无线码| 亚洲一区二区三区写真| 亚洲综合无码无在线观看| 亚洲精品中文字幕| 亚洲成a∧人片在线观看无码 | 野花香高清在线观看视频播放免费| 一级毛片正片免费视频手机看 | 99re热精品视频国产免费| 美女被免费视频网站| 国产亚洲精品国产福利在线观看| 亚洲日本乱码一区二区在线二产线|