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

勤能補(bǔ)拙,Expter

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

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

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

                例子如下:

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

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

                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}

 

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

        

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

評論

# 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;
}
}  回復(fù)  更多評論   

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

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

# 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;
}  回復(fù)  更多評論   

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

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

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

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

# 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)吧  回復(fù)  更多評論   

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

感覺不錯哦  回復(fù)  更多評論   

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

eric  回復(fù)  更多評論   

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

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

# 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;
}  回復(fù)  更多評論   

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

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

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

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

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

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美日本国产有色| 国内精品免费午夜毛片| 在线观看欧美黄色| 久久亚洲欧美国产精品乐播| 亚洲男人的天堂在线| 国产精品尤物| 久久午夜色播影院免费高清| 久久人人爽爽爽人久久久| 亚洲人久久久| 夜夜精品视频| 国产一区二区三区自拍| 欧美不卡在线视频| 欧美日韩国产成人精品| 亚洲男同1069视频| 久久久7777| 夜夜精品视频| 亚洲欧美日韩国产一区二区| 在线观看的日韩av| 一本高清dvd不卡在线观看| 国产精品久久一级| 欧美aⅴ一区二区三区视频| 欧美日韩不卡合集视频| 午夜宅男欧美| 欧美精品免费在线观看| 欧美影院午夜播放| 欧美成人精品高清在线播放| 亚洲一区二区三区视频| 久久国产精品一区二区三区四区| 激情伊人五月天久久综合| 亚洲伦理在线| 1769国产精品| 精品成人免费| 蜜桃av一区二区三区| 欧美视频中文字幕| 免费一级欧美在线大片| 国产精品久久一卡二卡| 欧美成人免费全部| 欧美精品久久一区| 久久国产视频网站| 欧美日韩亚洲综合一区| 久久久久网站| 国产精品日韩欧美综合| 亚洲精品黄色| 国内精品久久久久久久97牛牛| 99国产精品视频免费观看| 樱桃成人精品视频在线播放| 一本一本久久| 亚洲精品一区二区三区四区高清| 欧美一区激情| 香蕉乱码成人久久天堂爱免费| 欧美国产视频在线观看| 久久在线免费观看| 国产裸体写真av一区二区| 日韩一级黄色大片| 99在线|亚洲一区二区| 久久精品国产亚洲高清剧情介绍| 亚洲影院色无极综合| 欧美日韩黄色大片| 亚洲国产日韩精品| 亚洲二区在线视频| 久久视频一区二区| 免费日韩成人| 尤物在线精品| 久久婷婷一区| 欧美好吊妞视频| 最新国产拍偷乱拍精品| 久久久五月天| 欧美福利专区| 99在线视频精品| 欧美日韩国产页| 一本色道久久综合精品竹菊| 亚洲视频在线观看视频| 国产精品美女www爽爽爽| 宅男精品视频| 欧美综合第一页| 激情综合激情| 欧美福利视频| 宅男噜噜噜66一区二区66| 午夜精品久久久久久久蜜桃app| 国产精品99一区| 欧美一区午夜精品| 免费成人高清在线视频| 亚洲精品美女在线观看| 欧美日韩免费一区二区三区| 一区二区激情视频| 久久精品国产欧美亚洲人人爽| 国产综合精品一区| 欧美福利一区二区三区| 一本久久综合| 久久精品国产亚洲精品| 亚洲成人在线网| 欧美日韩国产在线观看| 欧美一级电影久久| 欧美激情91| 香蕉成人久久| 亚洲国产精品电影| 欧美午夜精品久久久久久久| 午夜精品视频网站| 亚洲电影观看| 欧美一级视频精品观看| 欧美激情中文字幕乱码免费| 欧美一区二区视频在线观看2020| 黄色成人在线网站| 欧美精品在线免费| 欧美亚洲视频一区二区| 亚洲国产专区| 欧美在线中文字幕| aa亚洲婷婷| 伊人狠狠色j香婷婷综合| 欧美日韩一区二区视频在线| 久久精品123| 亚洲视频axxx| 亚洲精品国产视频| 久久米奇亚洲| 亚洲新中文字幕| 91久久精品国产91久久性色tv | 久久九九精品99国产精品| 亚洲人成人一区二区三区| 国产精品一区二区三区久久| 麻豆成人综合网| 羞羞答答国产精品www一本 | 麻豆精品在线视频| 亚洲欧美经典视频| 一个色综合导航| 影音先锋日韩有码| 国产日本亚洲高清| 香港久久久电影| 中国女人久久久| 亚洲精品一区在线观看香蕉| 国内久久婷婷综合| 国产精品亚洲综合色区韩国| 欧美日韩情趣电影| 欧美高清视频| 美女黄色成人网| 另类综合日韩欧美亚洲| 久久爱www.| 欧美专区在线播放| 性高湖久久久久久久久| 亚洲欧美日韩第一区| 亚洲天堂偷拍| 亚洲一区二区在线观看视频| 亚洲六月丁香色婷婷综合久久| 欧美国产精品久久| 欧美激情第五页| 亚洲欧洲日韩在线| 亚洲精品少妇30p| 99av国产精品欲麻豆| 亚洲美女中文字幕| 一区二区三欧美| 亚洲午夜女主播在线直播| 中文成人激情娱乐网| 亚洲性感美女99在线| 亚洲制服av| 久久国产黑丝| 蜜臀99久久精品久久久久久软件| 裸体一区二区| 欧美日韩一级黄| 国产精品一区二区久久久| 国产日产亚洲精品系列| 国内精品久久久久久久97牛牛| 精品成人a区在线观看| 亚洲人永久免费| 亚洲私拍自拍| 久久久久国产一区二区| 欧美国产激情二区三区| 亚洲精选国产| 午夜欧美视频| 男男成人高潮片免费网站| 欧美久久一级| 国产欧美不卡| 亚洲精品裸体| 亚洲欧美在线免费| 老色批av在线精品| 最近中文字幕mv在线一区二区三区四区| 欧美阿v一级看视频| 美女黄色成人网| 国产精品户外野外| 在线欧美日韩国产| 亚洲天堂av高清| 美女脱光内衣内裤视频久久影院 | 亚洲欧美国产精品桃花| 久久综合给合久久狠狠色 | 久久aⅴ乱码一区二区三区| 免费看亚洲片| 国产精品一级二级三级| 亚洲大胆人体在线| 欧美一二三视频| 亚洲国产一二三| 午夜久久一区| 国产精品theporn88| 亚洲国产精品一区二区三区| 亚洲综合色视频| 亚洲国产婷婷香蕉久久久久久99| 午夜久久tv| 欧美先锋影音| 99精品视频一区| 欧美不卡在线视频| 久久不射中文字幕| 国产精品日韩久久久久| 在线亚洲精品|