• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            勤能補(bǔ)拙,Expter

            成都游戲Coder,記錄游戲開發(fā)過程的筆記和心得!

            一個(gè)問題,如何優(yōu)化? 是否有高效的算法

                    問題描述如下:
                            2個(gè)整數(shù)(int32),我需要對(duì)這2個(gè)數(shù)的第n位進(jìn)行二進(jìn)制數(shù)交換值。是否有一個(gè)高效的算法,或者高效的運(yùn)算。

                            例子如下:

                            2個(gè)整數(shù)10,7,把第1位的數(shù)值交換。

                           整數(shù)          二進(jìn)制        交換后二進(jìn)制       交換后的值

                            10             0x1010        0x1011                   11

                            7               0x0111        0x0110                   6

                           

                         我的思路如下:

                          1.如果要對(duì)第n位數(shù)值交換,先求出第n位的值(1或者0),如果相等則不交換。

                          2.交換第n位,通過通過原理發(fā)現(xiàn)只需通過加減法運(yùn)算即可,如果1->0 則減   1<<(n-1)  ,否則加1<<(n-1)。

            代碼如下:

             1void   prjfun( int & des , int & src , int n)
             2{
             3    if( n <= 0 ) return ;
             4
             5    int x = (des & (1<<(n-1))) >>(n-1);   // 求出第n位的數(shù)值
             6    int y = (src & (1<<(n-1))) >>(n-1);   // 求出第n位的數(shù)值
             7    if ( x != y )
             8    {
             9        des += (y-x)*(1<<(n-1));          // 交換
            10        stc += (x-y)*(1<<(n-1));          // 交換
            11    }

            12}

             

                       是否有一種高效的算法,只是進(jìn)行一,兩步位與或運(yùn)算即可。。

                    

            posted on 2009-10-18 22:27 expter 閱讀(2045) 評(píng)論(13)  編輯 收藏 引用 所屬分類: 其他學(xué)習(xí)筆記工作筆記算法與數(shù)據(jù)結(jié)構(gòu)

            評(píng)論

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法[未登錄] 2009-10-18 23:43 Eric

            你可以試試這樣
            int mask[32]={0x1,0x2,0x4,0x8,0x10...........};
            void fun( int & a , int & b , int n )
            {
            int c=mask[n-1];
            if ( ( a&c )!=( b&c ) ) {
            a=a^c;
            b=b^c;
            }
            }  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法 2009-10-18 23:56 夜風(fēng)

            你這個(gè)算法有很多是多余的,而且位運(yùn)算就少用+、-,看看下面的算法,感覺不錯(cuò)哦
            bool prjfun( int & des , int & src , int n)
            {
            if(n <= 0)
            return false;
            int mask = 1 << (n-1);
            if((des & mask) != (src & mask))
            {
            des ^= mask;
            src ^= mask;
            }
            return true;
            }  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法 2009-10-19 00:19 lucifer

            可以不需要if判斷語句的,
            void prjfun( int & des , int & src , int n)
            {
            if( n <= 0 ) return ;

            int x=(des&(1<<(n-1)))-(src&(1<<(n-1)));
            des-=x;
            src+=x;
            }  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法 2009-10-19 09:09 Fox

            支持@Eric
              回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法[未登錄] 2009-10-19 10:23 alex-lee

            Eric算法好  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法 2009-10-19 12:40 wangjinhu

            void f(int& a,int& b,int n)
            {
            int c = a&(1<<n);
            a = (a&(~(1<<n)))|(b&(1<<n));
            b = (b&(~(1<<n)))|c;
            }
            這樣多整齊啊,要是要判斷n
            那也得
            if(n<0 || n>31)吧  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法 2009-10-19 14:55 淘寶皇冠店

            感覺不錯(cuò)哦  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法[未登錄] 2009-10-19 16:58 vincent

            eric  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法[未登錄] 2009-10-19 17:29 goteet

            & | 是基本把  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法[未登錄] 2009-10-19 20:01 Eric

            @Eric
            我想了下,條件判斷還是可以去掉的:
            int mask[33]={0,0x1,0x2,0x4,0x8,0x10......};
            void fun( int & a , int & b , int n )
            {
            int c=(a^b)&mask[n];
            a^=c;
            b^=c;
            }  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法 2009-10-19 20:26 expter

            @Eric
            @wangjinhu
            的方法不錯(cuò),學(xué)習(xí)了。。。  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法 2009-10-21 12:59 阿福

            我有一種辦法,應(yīng)該是最快的:
            把顯示器倒過來,哈哈!  回復(fù)  更多評(píng)論   

            # re: 一個(gè)問題,如何優(yōu)化? 是否有高效的算法 2009-10-22 09:29 李佳

            樓上很風(fēng)趣   回復(fù)  更多評(píng)論   

            东方aⅴ免费观看久久av| 97精品伊人久久大香线蕉| 亚洲精品乱码久久久久久按摩 | 97久久香蕉国产线看观看| 久久久久人妻精品一区二区三区| 久久人人爽人爽人人爽av| 国产成人精品久久亚洲高清不卡 | 久久久久亚洲爆乳少妇无| 怡红院日本一道日本久久 | 成人亚洲欧美久久久久| 精品久久人人爽天天玩人人妻| 欧美久久精品一级c片片| 亚洲欧洲精品成人久久奇米网| 国产精品一区二区久久| 一级女性全黄久久生活片免费 | 91精品国产综合久久久久久| 色综合久久中文字幕综合网| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 精品国产青草久久久久福利| 精品99久久aaa一级毛片| 天天躁日日躁狠狠久久| 日本久久中文字幕| 久久久久一区二区三区| 浪潮AV色综合久久天堂| 久久综合亚洲色HEZYO社区| 久久精品国产99国产电影网| 影音先锋女人AV鲁色资源网久久 | 午夜福利91久久福利| 久久精品无码一区二区三区| 久久人人爽人人爽人人AV | 国色天香久久久久久久小说| 日本精品一区二区久久久| 久久人人爽人爽人人爽av| 国产精品九九久久精品女同亚洲欧美日韩综合区| 亚洲国产精品无码久久久不卡| 久久久久久伊人高潮影院| 久久无码人妻精品一区二区三区| 国内精品久久久久久中文字幕| 色综合久久中文色婷婷| 精品无码久久久久久久久久 | 91秦先生久久久久久久|