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

勤能補拙,Expter

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

一個問題,如何優化? 是否有高效的算法

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

                例子如下:

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

               整數          二進制        交換后二進制       交換后的值

                10             0x1010        0x1011                   11

                7               0x0111        0x0110                   6

               

             我的思路如下:

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

              2.交換第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位的數值
 6    int y = (src & (1<<(n-1))) >>(n-1);   // 求出第n位的數值
 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 閱讀(2069) 評論(13)  編輯 收藏 引用 所屬分類: 其他學習筆記工作筆記算法與數據結構

評論

# re: 一個問題,如何優化? 是否有高效的算法[未登錄] 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: 一個問題,如何優化? 是否有高效的算法 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: 一個問題,如何優化? 是否有高效的算法 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: 一個問題,如何優化? 是否有高效的算法 2009-10-19 09:09 Fox

支持@Eric
  回復  更多評論   

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

Eric算法好  回復  更多評論   

# re: 一個問題,如何優化? 是否有高效的算法 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: 一個問題,如何優化? 是否有高效的算法 2009-10-19 14:55 淘寶皇冠店

感覺不錯哦  回復  更多評論   

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

eric  回復  更多評論   

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

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

# re: 一個問題,如何優化? 是否有高效的算法[未登錄] 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: 一個問題,如何優化? 是否有高效的算法 2009-10-19 20:26 expter

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

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

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

# re: 一個問題,如何優化? 是否有高效的算法 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>
            中文国产亚洲喷潮| 在线观看日韩av先锋影音电影院| 亚洲精品小视频在线观看| 欧美成人tv| 欧美www视频| 香蕉免费一区二区三区在线观看 | 国产精品99久久久久久久久久久久 | 久久精品卡一| 久久久久久夜| 亚洲一区二区毛片| 午夜视频一区二区| 亚洲一区二区视频在线| 在线成人激情| 亚洲免费久久| 亚洲国产精品专区久久| 亚洲一区二区三区在线看| 亚洲第一色中文字幕| 久久国内精品视频| 亚洲素人在线| 欧美国产日产韩国视频| 欧美xx视频| 国外精品视频| 久久久久久久一区二区三区| 欧美中文在线免费| 欧美日韩午夜激情| 亚洲国产成人porn| 亚洲国产导航| 欧美精品1区2区3区| 日韩亚洲综合在线| 亚洲欧美中文日韩v在线观看| 欧美日韩在线影院| 欧美色精品天天在线观看视频 | 一区二区三区在线观看视频| 亚洲在线免费观看| 欧美一站二站| 国产精品久久久久9999高清| 99国产精品自拍| 欧美一区二区精品久久911| 国产美女精品在线| 久久资源在线| 99精品视频免费观看视频| 亚洲一区二区高清视频| 国产精品无码专区在线观看| 欧美一区二区三区免费视| 欧美aⅴ一区二区三区视频| 亚洲国产人成综合网站| 欧美色欧美亚洲另类二区 | 国产女优一区| 欧美精品大片| 久久久亚洲综合| 亚洲一区免费网站| 亚洲日本欧美日韩高观看| 久久精品首页| 午夜精品久久久久久久白皮肤| 伊人久久av导航| 国产精品嫩草99av在线| 欧美久久久久久| 欧美另类综合| 欧美成年人网站| 美女999久久久精品视频| 久久精品夜夜夜夜久久| 欧美一区1区三区3区公司| 亚洲一区二区在| 亚洲欧美精品suv| 亚洲在线免费| 午夜精品视频在线观看一区二区| 99视频精品免费观看| av不卡在线观看| 亚洲视频1区2区| 欧美 日韩 国产在线| 中文久久精品| 久久免费视频网| 欧美成人a视频| 99国产精品久久久久久久久久| 99亚洲一区二区| 久久久久国产免费免费| 美日韩在线观看| 国产精品三上| 99re6这里只有精品| 免费久久99精品国产| 久久免费精品视频| 欧美aⅴ一区二区三区视频| 欧美大香线蕉线伊人久久国产精品| 美女性感视频久久久| 亚洲伦伦在线| 久久综合精品国产一区二区三区| 欧美精品v日韩精品v韩国精品v| 国产精品日韩在线播放| 亚洲成色www8888| 欧美一区二区三区免费看 | 亚洲精品免费观看| 久久久久久9| 欧美大片在线看| 国产综合网站| 亚洲欧美日韩一区在线观看| 亚洲电影av| 久久久国产成人精品| 国产欧美激情| 亚洲综合色丁香婷婷六月图片| 欧美成人免费在线| 欧美一区午夜精品| 国产精品成人一区二区三区夜夜夜| 亚洲国产精品久久精品怡红院| 久久精品官网| 欧美综合国产| 在线观看亚洲一区| 免费观看在线综合| 蜜臀久久99精品久久久久久9| 激情婷婷久久| 欧美成ee人免费视频| 女人天堂亚洲aⅴ在线观看| 亚洲第一视频网站| 亚洲精品欧洲精品| 国产精品av一区二区| 欧美在线你懂的| 欧美大片国产精品| 亚洲欧美欧美一区二区三区| 亚洲欧美日韩在线观看a三区| 国产精品久久久久久久7电影| 久久久综合激的五月天| 亚洲综合色丁香婷婷六月图片| 免费一级欧美在线大片| 国产精品任我爽爆在线播放| 亚洲精品日本| 亚洲在线一区二区| 91久久精品日日躁夜夜躁欧美 | 午夜精品成人在线| 91久久久久久国产精品| 亚洲一区二区av电影| 一色屋精品视频在线看| 亚洲午夜久久久久久尤物 | 欧美精选在线| 亚洲在线成人| 欧美福利影院| 亚洲高清不卡在线观看| 国产美女精品视频| 99国产一区| 一区二区三区黄色| 免费一级欧美片在线观看| 久久综合给合久久狠狠狠97色69| 国产精品久久久久av免费| 亚洲韩国精品一区| 亚洲国产高清自拍| 免费成年人欧美视频| 欧美成人自拍视频| 亚洲国产成人高清精品| 久久久91精品| 亚洲黄色在线视频| 亚洲少妇一区| 国产一区二区三区四区| 久久国产精品一区二区| 欧美成人精品不卡视频在线观看| 一区二区三区中文在线观看| 久久蜜臀精品av| 亚洲区欧美区| 久久九九热re6这里有精品| 黄色在线成人| 欧美日韩 国产精品| 99在线热播精品免费99热| 欧美在线亚洲在线| 91久久精品美女高潮| 国产精品a级| 免费成人性网站| 亚洲性图久久| 99视频有精品| 蜜臀99久久精品久久久久久软件| 一区二区三区|亚洲午夜| 国产一区二区三区观看| 欧美日韩国产片| 久久综合伊人77777蜜臀| 亚洲综合日韩中文字幕v在线| 亚洲福利视频一区二区| 久久精品视频在线观看| 亚洲欧美成人一区二区在线电影| 亚洲高清资源| 精品福利电影| 在线播放日韩专区| 国产在线欧美| 国产日韩精品一区观看| 久久久精品免费视频| 一区二区三区四区五区精品| 91久久精品日日躁夜夜躁国产| 久久久久久九九九九| 久久久久久网址| 久久五月天婷婷| 免费观看一区| 欧美国产一区二区三区激情无套| 久久久亚洲午夜电影| 久久精品国产v日韩v亚洲| 久久深夜福利免费观看| 久久久久久久国产| 欧美激情精品| 99这里有精品| 新片速递亚洲合集欧美合集| 午夜精品视频在线| 免费成人av| 国产欧美日韩亚洲| 亚洲精品国产精品国自产观看浪潮 | 亚洲一区二区在线视频| 欧美一区二视频在线免费观看|