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

勤能補拙,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 閱讀(2066) 評論(13)  編輯 收藏 引用 所屬分類: 其他學習筆記工作筆記算法與數(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;
}
}  回復  更多評論   

# 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>
            亚洲图片在线观看| 亚洲国产精品免费| 一区二区三区视频在线观看| 国产一区二区三区四区hd| 欧美精品在线观看播放| 欧美岛国激情| 欧美激情一二三区| 欧美成年网站| 欧美网站大全在线观看| 国产精品一区在线观看| 国产九九精品视频| 伊人春色精品| 亚洲伦伦在线| 亚洲欧美日韩一区在线观看| 欧美一区二区精品| 久久综合九色欧美综合狠狠| 欧美激情视频一区二区三区在线播放 | 亚洲自拍电影| 欧美一区二区视频97| 欧美怡红院视频| 亚洲日本中文字幕区| 亚洲无玛一区| 毛片一区二区三区| 欧美视频在线免费看| 精品成人一区| 亚洲午夜久久久| 欧美成人午夜激情| 午夜激情一区| 国产精品白丝jk黑袜喷水| 曰韩精品一区二区| 欧美在线高清视频| 亚洲肉体裸体xxxx137| 欧美在线视频在线播放完整版免费观看| 噜噜噜噜噜久久久久久91| 国产精品你懂的在线| 日韩亚洲成人av在线| 久久久91精品国产| 一区二区三区日韩精品| 美玉足脚交一区二区三区图片| 国产精品欧美经典| 这里只有精品丝袜| 欧美国产视频在线| 久久aⅴ国产紧身牛仔裤| 国产精品h在线观看| 亚洲精品一线二线三线无人区| 欧美在线一二三四区| 亚洲深夜激情| 欧美日韩精品一区二区在线播放 | 午夜精品久久久久久99热软件| 欧美激情精品久久久久久久变态| 国产在线播放一区二区三区| 亚洲欧美色一区| 亚洲精品久久久蜜桃| 美女亚洲精品| 亚洲经典一区| 欧美激情中文字幕一区二区| 久久精品一级爱片| 精东粉嫩av免费一区二区三区| 欧美一区二区私人影院日本| 一本色道久久综合亚洲精品不卡| 欧美人与禽猛交乱配| 亚洲人午夜精品| 亚洲国产精品99久久久久久久久| 蜜臀av国产精品久久久久| 亚洲国产毛片完整版 | 亚洲高清不卡一区| 久久久久成人精品| 久久久视频精品| 亚洲国产裸拍裸体视频在线观看乱了| 美女视频黄免费的久久| 久久国产精品久久久久久| 欧美综合77777色婷婷| 国产视频在线观看一区 | 亚洲丶国产丶欧美一区二区三区| 久久电影一区| 亚洲国产精品va| 亚洲大片一区二区三区| 欧美精品成人91久久久久久久| 日韩视频免费看| 中文一区在线| 国产亚洲一区二区在线观看| 久久久www免费人成黑人精品| 久久精品国产成人| 日韩午夜三级在线| 亚洲欧美激情四射在线日| 国产欧美精品xxxx另类| 美女黄色成人网| 欧美日韩p片| 欧美在线一级va免费观看| 久久综合久久综合这里只有精品| 亚洲黄色小视频| 9国产精品视频| 国产亚洲一区在线| 亚洲电影免费观看高清完整版在线| 欧美风情在线| 欧美在线观看一二区| 免费短视频成人日韩| 亚洲午夜高清视频| 久久精品人人做人人综合| 一本久久综合亚洲鲁鲁| 新狼窝色av性久久久久久| 亚洲欧洲日本mm| 亚洲欧美国产另类| 日韩天堂av| 欧美一区二区三区另类| 一区二区三区不卡视频在线观看| 欧美在线|欧美| 亚洲天堂av高清| 女人天堂亚洲aⅴ在线观看| 亚洲欧美在线另类| 免费中文日韩| 六月婷婷久久| 国产精品一区一区| 99精品国产在热久久| 亚洲经典在线| 久久久久高清| 久久精品综合网| 欧美视频二区36p| 亚洲韩国精品一区| 亚洲高清在线精品| 欧美伊久线香蕉线新在线| 亚洲视频中文| 欧美精品尤物在线| 亚洲国产日韩欧美| 亚洲第一在线综合网站| 亚洲女人小视频在线观看| 亚洲影视综合| 国产精品mm| 亚洲美女网站| 亚洲私拍自拍| 欧美日韩在线亚洲一区蜜芽| 亚洲国产欧美久久| 亚洲国产视频一区| 欧美自拍偷拍午夜视频| 午夜免费日韩视频| 99re这里只有精品6| 午夜一区在线| 美日韩精品免费观看视频| 久热国产精品| 国产一区二区日韩| 欧美一级理论片| 久久精品中文字幕一区二区三区| 国产精品日韩在线| 亚洲欧美日韩国产一区| 亚洲欧美日本另类| 国产欧美激情| 久久精品国产综合精品| 卡一卡二国产精品| 亚洲第一在线综合在线| 美脚丝袜一区二区三区在线观看 | 亚洲美女av在线播放| 欧美精品1区2区3区| 最新精品在线| 亚洲一区二区动漫| 国产亚洲精品久久久久婷婷瑜伽| 欧美影院在线| 亚洲国产精品一区在线观看不卡| 亚洲国产综合在线看不卡| 欧美国产大片| 亚洲欧美国内爽妇网| 免费成人黄色| 亚洲天堂av图片| 韩国久久久久| 欧美激情综合亚洲一二区| 日韩一区二区精品| 欧美一区二区在线观看| 最新高清无码专区| 国产精品www994| 久久久久久亚洲精品中文字幕| 亚洲电影免费观看高清完整版| 亚洲一区二区在线免费观看| 国产小视频国产精品| 免费成人性网站| 亚洲欧美日韩国产中文 | 六月天综合网| 在线视频免费在线观看一区二区| 国产精品午夜国产小视频| 久久久久久日产精品| 亚洲网址在线| 亚洲大片av| 久久久av水蜜桃| 亚洲自拍偷拍视频| 亚洲国产欧美久久| 国产精品午夜春色av| 欧美成人在线免费观看| 亚洲精品自在久久| 免费成人你懂的| 久久精品国产69国产精品亚洲| 亚洲国产欧美另类丝袜| 国产亚洲欧洲997久久综合| 欧美日韩国产色视频| 久久九九热re6这里有精品| 99精品热6080yy久久 | 亚洲国产精品美女| 久久成人在线| 午夜老司机精品| 一本一道久久综合狠狠老精东影业| 激情一区二区三区| 国产情人节一区| 欧美视频在线一区二区三区|