青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

勤能補拙,Expter

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

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

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

                例子如下:

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

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

                10             0x1010        0x1011                   11

                7               0x0111        0x0110                   6

               

             我的思路如下:

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

              2.交換第n位,通過通過原理發(fā)現(xià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}

 

           是否有一種高效的算法,只是進行一,兩步位與或運算即可。。

        

posted on 2009-10-18 22:27 expter 閱讀(2057) 評論(13)  編輯 收藏 引用 所屬分類: 其他學習筆記工作筆記 、算法與數(shù)據(jù)結構

評論

# re: 一個問題,如何優(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;
}
}  回復  更多評論   

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

你這個算法有很多是多余的,而且位運算就少用+、-,看看下面的算法,感覺不錯哦
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;
}  回復  更多評論   

# re: 一個問題,如何優(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;
}  回復  更多評論   

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

支持@Eric
  回復  更多評論   

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

Eric算法好  回復  更多評論   

# re: 一個問題,如何優(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)吧  回復  更多評論   

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

感覺不錯哦  回復  更多評論   

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

eric  回復  更多評論   

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

& | 是基本把  回復  更多評論   

# re: 一個問題,如何優(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;
}  回復  更多評論   

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

@Eric
@wangjinhu
的方法不錯,學習了。。。  回復  更多評論   

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

我有一種辦法,應該是最快的:
把顯示器倒過來,哈哈!  回復  更多評論   

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

樓上很風趣   回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久色婷婷小香蕉久久| 欧美在线播放一区| 久久久久久久精| 亚洲精品日韩在线观看| 欧美有码视频| 亚洲欧美日韩综合| 日韩亚洲欧美成人| 亚洲人午夜精品免费| 伊人久久久大香线蕉综合直播| 国产精品igao视频网网址不卡日韩| 久久久国产精品一区二区中文| 亚洲午夜日本在线观看| 国内精品视频666| 国产精品普通话对白| 国产精品九色蝌蚪自拍| 欧美日韩你懂的| 欧美女激情福利| 欧美日本韩国一区| 欧美视频网址| 国产自产高清不卡| 91久久国产自产拍夜夜嗨| 老司机精品导航| 一区二区三区四区五区精品| 一本不卡影院| 久久久久久久久久看片| 亚洲毛片在线| 久久综合中文| 国产中文一区| 午夜国产精品视频| 亚洲二区精品| 欧美影院成人| 午夜免费日韩视频| 久久综合久色欧美综合狠狠 | 国产精品视频九色porn| 韩日在线一区| 欧美伊人精品成人久久综合97 | 久久这里有精品视频| 免费精品视频| 久久久久久久久一区二区| 校园春色国产精品| 久久夜色精品国产亚洲aⅴ| 国产欧美一区二区色老头| 国产视频欧美视频| 亚洲自拍三区| 亚洲日本aⅴ片在线观看香蕉| 中文亚洲字幕| 欧美久色视频| 亚洲尤物精选| 国产精品v一区二区三区 | 亚洲一区二区三区在线视频| 亚洲综合好骚| 亚洲一级二级在线| 欧美日本精品| 亚洲欧洲一区二区在线观看 | 欧美大片网址| 国产综合在线视频| 久久精品卡一| 亚洲欧美一区二区激情| 欧美劲爆第一页| 亚洲国产日韩欧美在线动漫| 小处雏高清一区二区三区| 午夜在线播放视频欧美| 国产精品久久夜| 99riav1国产精品视频| 暖暖成人免费视频| 欧美在线你懂的| 伊人成人在线| 亚洲国产高清在线| 欧美岛国在线观看| 99热在这里有精品免费| 欧美黑人在线观看| 蜜臀久久99精品久久久久久9| 国产精品99久久久久久白浆小说 | 老鸭窝毛片一区二区三区| 亚洲国产精品一区二区久| 亚洲精品在线三区| 欧美亚一区二区| 女人天堂亚洲aⅴ在线观看| 欧美韩日亚洲| 久久久久久久综合| 欧美国产欧美亚州国产日韩mv天天看完整| 91久久国产综合久久| 一区二区三区高清在线| 狠狠久久婷婷| 亚洲午夜精品网| 日韩亚洲一区二区| 久久久久国产成人精品亚洲午夜| 艳妇臀荡乳欲伦亚洲一区| 久久精品91| 99精品福利视频| 欧美福利视频网站| 麻豆久久婷婷| 国产一区二区三区最好精华液| 亚洲卡通欧美制服中文| 亚洲高清免费视频| 欧美在线一二三| 亚洲欧美国产77777| 欧美日韩在线一区二区| 久久午夜视频| 久久在线免费视频| 久久在线免费| 在线不卡视频| 欧美激情第一页xxx| 亚洲精品一区二区网址| 日韩视频免费大全中文字幕| 老牛影视一区二区三区| 欧美在线播放高清精品| 欧美在线三级| 欧美aaaaaaaa牛牛影院| 在线播放豆国产99亚洲| 欧美日韩视频第一区| 亚洲精品中文在线| 欧美一区二区三区视频| 玖玖玖免费嫩草在线影院一区| 国自产拍偷拍福利精品免费一| 性欧美激情精品| 亚洲高清视频一区二区| 亚洲一区二区三区777| 黄色欧美成人| 国产精品毛片大码女人| 久久九九99视频| 亚洲国产精品久久久久久女王| 欧美一区二区久久久| 亚洲人成网站在线播| 国产精品自拍三区| 欧美裸体一区二区三区| 免费在线亚洲| 欧美在线观看视频一区二区| 99精品国产在热久久婷婷| 美女脱光内衣内裤视频久久影院| 国产精品99久久久久久宅男| 伊人激情综合| 黑人一区二区三区四区五区| 国产精品久久一卡二卡| 亚洲高清一区二| 亚洲国产成人91精品| 美女诱惑一区| 欧美好吊妞视频| 亚洲国产午夜| 亚洲精品在线一区二区| 亚洲精品视频免费| 夜色激情一区二区| 一区二区三区精品| 亚洲午夜一区二区| 性亚洲最疯狂xxxx高清| 欧美一区二区视频97| 久久天堂av综合合色| 欧美一区二区视频网站| 亚洲欧美日韩天堂| 午夜在线视频观看日韩17c| 午夜久久电影网| 亚洲婷婷免费| 久久人人97超碰人人澡爱香蕉| 久久婷婷激情| 欧美在线观看你懂的| 亚洲欧洲一区二区在线观看 | 美女主播精品视频一二三四| 欧美va亚洲va日韩∨a综合色| 亚洲国产成人av| 亚洲午夜av| 久久电影一区| 99re这里只有精品6| 欧美一级理论片| 欧美色中文字幕| 亚洲人成绝费网站色www| 久久精品中文字幕一区二区三区| 久久综合九色欧美综合狠狠| 国产欧美日韩三区| 在线观看日韩欧美| 久久国产精品网站| 9色porny自拍视频一区二区| 欧美极品在线播放| 亚洲欧美日韩直播| 久久成人羞羞网站| 亚洲精品免费在线观看| 亚洲自啪免费| 亚洲国产精品第一区二区三区| 亚洲国产精品成人综合色在线婷婷| 欧美精品一区二区三区在线播放| 日韩一区二区精品葵司在线| 欧美第十八页| 国产精品久久久久久久久久久久 | 欧美在线免费观看视频| 噜噜噜噜噜久久久久久91| 亚洲综合色激情五月| 久久露脸国产精品| 欧美激情精品久久久| 久久精彩视频| 国产精品一区久久| 一区二区电影免费观看| 亚洲激情黄色| 老司机成人网| 免费在线欧美视频| 黄色亚洲网站| 久久精品三级| 欧美国产先锋| 99www免费人成精品| 欧美—级高清免费播放| 亚洲久久一区二区| 亚洲无限av看|