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

勤能補(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>
            欧美一区二区三区播放老司机| 国产精品网站在线观看| 亚洲激情另类| 欧美成人免费va影院高清| 久久尤物视频| 欧美国产日韩视频| 亚洲黄色免费电影| 一区二区三区.www| 午夜亚洲精品| 久久夜色精品国产欧美乱| 欧美一级夜夜爽| 欧美二区视频| 国产美女高潮久久白浆| 亚洲国产精品成人精品| 中文欧美在线视频| 久久影院午夜片一区| 亚洲精品国产精品乱码不99按摩 | 99精品欧美一区二区三区| 99re6热只有精品免费观看| 亚洲一区综合| 久久综合色一综合色88| 91久久精品www人人做人人爽| 制服丝袜亚洲播放| 久久综合网色—综合色88| 欧美日韩精品综合| 在线看视频不卡| 午夜老司机精品| 最新国产成人在线观看| 久久国产精品一区二区三区四区| 麻豆视频一区二区| 国产亚洲欧美在线| 在线亚洲精品| 亚洲视频免费观看| 欧美性猛交xxxx乱大交退制版| 亚洲国产精品精华液2区45| 欧美大片在线观看一区二区| 久久人人精品| 亚洲日本一区二区三区| 浪潮色综合久久天堂| 久久综合电影| 日韩视频在线观看国产| 亚洲国产欧美一区二区三区同亚洲 | 国产精品扒开腿做爽爽爽视频| aa级大片欧美三级| 美女在线一区二区| a4yy欧美一区二区三区| 99re6这里只有精品| 国产欧美一区二区三区另类精品 | 夜夜精品视频一区二区| 99精品久久久| 伊人春色精品| 99精品99久久久久久宅男| 欧美视频在线免费| 免费91麻豆精品国产自产在线观看| 久久人人97超碰国产公开结果| 亚洲综合日韩在线| 欧美日韩激情网| 欧美一区二区三区视频在线观看| 国产精品99久久久久久www| 亚洲视频一区二区| 亚洲国产美女精品久久久久∴| 91久久在线| 国产欧美一区二区三区国产幕精品 | 亚洲午夜久久久久久久久电影院| 国产精品网站在线播放| 欧美成人在线免费视频| 国产精品三区www17con| 男人的天堂成人在线| 国产精品久久久久久妇女6080 | 夜夜嗨av一区二区三区网页| 久热精品视频| 亚洲精品小视频在线观看| 一区二区高清在线观看| 国产精品精品视频| 久热爱精品视频线路一| 国产视频一区三区| 亚洲一区免费网站| 午夜精品久久久久久久99热浪潮| 欧美大片免费观看| 亚洲免费成人| 亚洲欧美中文另类| 又紧又大又爽精品一区二区| 久久精品亚洲精品| 亚洲精品美女在线观看| 在线综合亚洲欧美在线视频| 欧美亚洲成人免费| 欧美一区二区在线播放| 裸体歌舞表演一区二区| 日韩网站在线观看| 欧美国产精品劲爆| 99天天综合性| 国产午夜精品美女视频明星a级| 久久国产精品黑丝| 亚洲国产清纯| 欧美与欧洲交xxxx免费观看 | 久久久久综合网| 久久在线免费视频| 亚洲欧美日韩一区在线| 黄色亚洲免费| 国产精品视区| 欧美日韩亚洲一区在线观看| 亚洲一区自拍| 亚洲一区二区三区免费视频| 欧美韩日一区二区三区| 久久精品国产亚洲一区二区| 日韩视频在线一区| 欧美日韩一区在线观看视频| 欧美一区三区三区高中清蜜桃| 欧美国产在线电影| 久久综合伊人| 久久久青草青青国产亚洲免观| 99视频在线精品国自产拍免费观看 | 亚洲精选一区| 亚洲日本成人| 亚洲伦理网站| 亚洲一区二区免费视频| 国产精品99久久99久久久二8| 亚洲免费福利视频| 亚洲日本黄色| 中文在线资源观看网站视频免费不卡| 亚洲激情电影在线| 亚洲欧洲一区二区天堂久久| 久久久视频精品| 久久理论片午夜琪琪电影网| 亚洲欧美制服另类日韩| 午夜精彩视频在线观看不卡 | 国产一区二区三区高清| 一区二区三区自拍| 亚洲欧洲一区二区天堂久久| 亚洲美女视频网| 欧美一区二区三区在线免费观看| 欧美一区二区三区在线看| 欧美电影免费观看网站| 99国产精品一区| 欧美一级黄色网| 欧美日韩国产小视频| 狠狠操狠狠色综合网| 一区二区高清视频| 亚洲国产经典视频| 亚洲一区久久久| 国产精品高清网站| 亚洲国产精品久久久久秋霞蜜臀 | 欧美精品一区二区三区在线看午夜| 欧美激情网站在线观看| 国产一区二区欧美日韩| 欧美一区二区三区喷汁尤物| 夜夜躁日日躁狠狠久久88av| 久久综合给合久久狠狠色| 国产亚洲免费的视频看| 国产精品v日韩精品| 欧美大片网址| 亚洲国产精品久久久| 欧美国产在线电影| 久久网站免费| 亚洲精品午夜精品| 激情综合电影网| 久久综合精品国产一区二区三区| 亚洲天堂男人| 国产精品av免费在线观看| 亚洲欧美综合v| 欧美一区成人| 在线观看成人av| 亚洲欧洲一区二区三区| 国产精品久久久久国产精品日日| 午夜在线一区| 欧美啪啪一区| 久久午夜影视| 欧美日韩免费观看一区二区三区| 中国成人亚色综合网站| 性色av一区二区三区在线观看| 国语精品一区| 欧美亚洲一级片| 亚洲欧美美女| 欧美日韩国产片| 欧美va天堂va视频va在线| 国产精品久久一级| 亚洲黄色成人网| 极品日韩av| 亚洲欧美日本国产专区一区| 亚洲免费电影在线| 欧美不卡视频一区发布| 久久视频国产精品免费视频在线 | 99精品热视频只有精品10| 国产亚洲午夜高清国产拍精品| 亚洲精品网站在线播放gif| 黑人巨大精品欧美一区二区小视频| 亚洲精品日产精品乱码不卡| 在线成人小视频| 久久伊人一区二区| 久久综合影视| 亚洲人成在线观看一区二区| 久久视频免费观看| 欧美国产精品v| 99riav久久精品riav| 欧美激情一区二区三区蜜桃视频 | 国产精品性做久久久久久| 亚洲婷婷综合久久一本伊一区| 欧美性理论片在线观看片免费| 亚洲精品久久7777| 一区二区高清视频在线观看|