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

勤能補拙,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>
            欧美不卡视频一区| 亚洲欧美日韩视频一区| 欧美h视频在线| 亚洲欧洲日本国产| 亚洲精品国精品久久99热一| 欧美激情成人在线视频| 久久精品一区二区国产| 亚洲欧美中文日韩在线| 激情一区二区三区| 亚洲风情亚aⅴ在线发布| 欧美伦理a级免费电影| 亚洲欧美不卡| 久久国产色av| 日韩一级在线| 午夜伦理片一区| 亚洲国产精品电影| 亚洲小少妇裸体bbw| 在线成人免费视频| 中文成人激情娱乐网| 国产一区二区你懂的| 91久久精品日日躁夜夜躁国产| 欧美性猛交xxxx乱大交蜜桃| 久久女同互慰一区二区三区| 欧美日韩国产电影| 久久一综合视频| 欧美日韩亚洲免费| 欧美成在线视频| 国产欧美午夜| 亚洲伦理自拍| 亚洲国产精品va在看黑人| 亚洲一区二区三区成人在线视频精品| 影视先锋久久| 亚洲一区二区免费视频| 亚洲美女91| 久久综合给合久久狠狠狠97色69| 亚洲在线成人| 欧美日韩国产综合新一区| 免费在线亚洲欧美| 国产欧美日韩不卡| 夜夜嗨av一区二区三区四区| 亚洲欧洲一区二区三区久久| 久久精品一区二区三区中文字幕| 亚洲一区二区精品在线观看| 欧美成人精品一区二区| 久久三级视频| 国产精品一区久久久久| 99综合电影在线视频| 91久久精品国产91久久性色tv| 欧美在线播放一区| 欧美一二三视频| 国产精品vip| 99精品99| 亚洲神马久久| 欧美日韩另类字幕中文| 亚洲人成艺术| 99re6这里只有精品| 欧美电影在线免费观看网站| 欧美激情精品久久久久久蜜臀 | 国产精品一区二区在线观看不卡| 日韩一二三区视频| 一区二区三区www| 欧美日韩国产亚洲一区 | 亚洲男女毛片无遮挡| 欧美午夜电影网| 亚洲一区日韩在线| 欧美在线电影| 国产一区二区精品丝袜| 性欧美大战久久久久久久久| 18成人免费观看视频| 欧美主播一区二区三区美女 久久精品人 | 欧美中文在线观看国产| 久久久久久久综合狠狠综合| 国内精品视频666| 久久九九免费| 亚洲第一区色| 野花国产精品入口| 国产精品自拍小视频| 欧美在线一二三| 六月天综合网| 99精品国产高清一区二区| 欧美日韩一区在线观看视频| 亚洲综合精品四区| 美女视频黄a大片欧美| 亚洲精品一区久久久久久| 欧美私人网站| 久久爱另类一区二区小说| 欧美不卡在线| 亚洲一区二区三区免费在线观看| 国产欧美日韩免费| 欧美11—12娇小xxxx| 一区二区三区鲁丝不卡| 久久在线免费视频| 99国内精品久久久久久久软件| 国产精品日韩久久久| 久久乐国产精品| 日韩天堂在线视频| 久久人人爽爽爽人久久久| 99视频在线观看一区三区| 国产欧美精品一区二区三区介绍| 久久永久免费| 亚洲欧美国产一区二区三区| 欧美激情一区在线观看| 午夜精品一区二区在线观看| 亚洲国产精彩中文乱码av在线播放| 国产精品国产一区二区| 久久综合亚洲社区| 亚洲欧美日韩在线播放| 亚洲国产成人av| 久久网站免费| 欧美一级精品大片| 艳妇臀荡乳欲伦亚洲一区| 国产亚洲欧美日韩一区二区| 欧美日韩精品一区二区| 久久精品二区| 亚洲欧美综合国产精品一区| 99视频有精品| 亚洲福利免费| 免费在线看一区| 久久久在线视频| 午夜一级久久| 亚洲婷婷在线| 一本久道久久久| 亚洲精品久久久久| 亚洲国产精品久久久久秋霞蜜臀| 国产女优一区| 国产精品毛片大码女人| 欧美日韩成人综合在线一区二区 | 欧美一区二区啪啪| 亚洲午夜视频在线| 亚洲精品一区二区三区av| 欧美国产一区二区在线观看| 久久香蕉精品| 久久免费视频在线观看| 久久久久国产成人精品亚洲午夜| 午夜免费在线观看精品视频| 亚洲校园激情| 亚洲欧美激情诱惑| 午夜宅男久久久| 欧美一级午夜免费电影| 欧美一区二区三区在| 性一交一乱一区二区洋洋av| 国产日韩欧美一区| 国产一区二区看久久| 国产欧美一区二区精品忘忧草| 国产精品普通话对白| 国产精品久久久一区二区三区| 欧美视频在线不卡| 国产精品老女人精品视频| 国产精品免费观看在线| 国产日韩视频一区二区三区| 国产精品一区亚洲| 激情成人av| 91久久在线播放| 99在线热播精品免费| 亚洲在线播放| 久久青草欧美一区二区三区| 欧美承认网站| 一本色道久久| 小辣椒精品导航| 男女精品视频| 欧美香蕉大胸在线视频观看| 国产一区二区三区无遮挡| 亚洲国产精品高清久久久| 一本久久综合| 久久国产精品一区二区三区| 免费观看亚洲视频大全| 亚洲乱码国产乱码精品精天堂 | 猫咪成人在线观看| 亚洲国产三级网| 亚洲一区三区视频在线观看 | 午夜日韩在线观看| 久久一区二区三区超碰国产精品| 欧美精品粉嫩高潮一区二区| 国产欧美精品在线播放| 亚洲国产婷婷香蕉久久久久久99| 夜夜嗨av一区二区三区网站四季av| 午夜精品在线视频| 欧美激情一区二区三区| 在线视频欧美日韩| 久久综合色天天久久综合图片| 欧美亚韩一区| 亚洲精品1234| 久久久久久电影| 一区二区日韩欧美| 免费成年人欧美视频| 国产乱码精品一区二区三区av| 亚洲激情在线激情| 久久久久久久网站| 亚洲午夜精品福利| 欧美激情精品久久久久久蜜臀| 国产视频精品网| 一本色道久久综合精品竹菊| 免费成人高清视频| 午夜国产精品影院在线观看| 欧美精品久久99久久在免费线| 精品动漫av| 久久激情视频久久| 亚洲小说欧美另类婷婷| 欧美日韩免费一区二区三区视频| 亚洲第一福利在线观看|