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

勤能補拙,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 閱讀(2060) 評論(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>
            亚洲欧洲视频在线| 亚洲一区美女视频在线观看免费| 欧美freesex8一10精品| 亚洲激情黄色| 欧美 日韩 国产 一区| 国产精品看片你懂得| 亚洲欧洲日产国产综合网| 亚洲欧美日韩精品久久奇米色影视| 欧美成人在线免费观看| 日韩午夜激情av| 欧美激情一区二区三区成人 | 欧美a级片一区| 在线精品亚洲| 亚洲欧美另类国产| 欧美黄色aa电影| 国内成人在线| 亚洲福利视频网| 老司机aⅴ在线精品导航| 亚洲国产日本| 欧美激情区在线播放| 精品999在线播放| 老司机久久99久久精品播放免费 | 欧美激情精品久久久六区热门| 亚洲视频一区二区免费在线观看| 亚洲自拍电影| 欧美天堂亚洲电影院在线观看| a4yy欧美一区二区三区| 美女久久一区| 欧美电影免费| 亚洲乱码国产乱码精品精天堂| 亚洲国产成人午夜在线一区 | 国产精品综合色区在线观看| 亚洲视频图片小说| 亚洲小少妇裸体bbw| 欧美日韩国产电影| 欧美视频在线观看 亚洲欧| 亚洲午夜一区| 亚洲天堂成人在线观看| 国产欧美高清| 久久精品国产久精国产一老狼 | 久久精品人人做人人爽| 国产在线视频不卡二| 欧美国产成人在线| 欧美激情视频在线播放| 一本色道久久综合狠狠躁篇的优点| 亚洲国产精品久久人人爱蜜臀| 亚洲一区三区视频在线观看 | 亚洲女同性videos| 一区二区国产精品| 国产精品揄拍500视频| 午夜久久福利| 久久综合久久美利坚合众国| 麻豆久久婷婷| 玖玖国产精品视频| 99精品视频一区| 麻豆成人在线观看| 狠狠综合久久av一区二区老牛| 亚洲美女在线国产| 一区二区电影免费观看| 亚洲动漫精品| 久久精品99国产精品日本| 国产精品久久一卡二卡| 1769国产精品| 亚洲第一黄网| 久久久久久999| 伊人久久综合97精品| 午夜在线观看欧美| 亚洲一区观看| 欧美精品在线一区二区三区| 亚洲人成人一区二区三区| 久久精品国产视频| 亚洲欧美另类中文字幕| 亚洲欧美色一区| 一区二区高清视频在线观看| 欧美日韩国产成人在线观看| 黄色av日韩| 欧美专区在线| 亚洲欧美精品suv| 久久久久久久久久久久久9999| 欧美国产日韩精品免费观看| 亚洲精品国产无天堂网2021| 亚洲第一精品电影| 99综合视频| 亚洲欧美色婷婷| 国语精品中文字幕| 久久精品91久久久久久再现| 久久国产精品久久久| 国产视频观看一区| 午夜亚洲激情| 欧美尤物巨大精品爽| 欧美激情影院| 欧美亚洲一区| 亚洲精品综合| 精品69视频一区二区三区| 欧美亚洲免费电影| 午夜精品一区二区三区在线视 | 激情五月综合色婷婷一区二区| 亚洲免费小视频| 国产一区在线视频| 国产精品色一区二区三区| 亚洲高清自拍| 最近看过的日韩成人| 国产精品欧美一区二区三区奶水| 国产精品99久久久久久有的能看| 亚洲综合色网站| 狠狠色综合网站久久久久久久| 亚洲精品综合精品自拍| 国产精品另类一区| 亚洲第一网站免费视频| 欧美精品国产一区| 久久久综合视频| 欧美成ee人免费视频| 亚洲欧洲综合另类在线| 欧美永久精品| 欧美激情一区二区久久久| 亚洲欧美激情诱惑| 欧美精品一区二区三区在线播放| 一本久久综合亚洲鲁鲁| 久久久国产一区二区| 亚洲精品自在在线观看| 久久国产精品黑丝| 国产婷婷色一区二区三区四区| 日韩午夜电影| 午夜久久久久久| 欧美日韩一区二区在线播放| 鲁大师成人一区二区三区| 欧美中文在线观看| 久久成年人视频| 国模精品一区二区三区| 亚洲综合日本| 亚洲欧美一区在线| 亚洲国产精品成人久久综合一区| 欧美日韩一区二区在线视频| 亚洲第一主播视频| 91久久综合亚洲鲁鲁五月天| 在线视频欧美日韩| 欧美性淫爽ww久久久久无| 欧美一级精品大片| 一区二区三区四区国产精品| 欧美一区二区精美| 日韩视频精品| 欧美中文在线视频| 在线欧美电影| 亚洲先锋成人| 久久久久久综合网天天| 美日韩精品视频免费看| 亚洲精选视频免费看| 亚洲欧美日韩成人| 亚洲人精品午夜| 国产精品麻豆成人av电影艾秋| 欧美一区二区啪啪| 亚洲午夜免费福利视频| 欧美 日韩 国产一区二区在线视频| 亚洲欧美日本另类| 亚洲精品久久在线| 韩国福利一区| 久久香蕉国产线看观看av| 亚洲图片欧洲图片av| 欧美视频一区二| 亚洲精品美女在线| 亚洲免费中文字幕| 欧美三区在线| 毛片av中文字幕一区二区| 狂野欧美激情性xxxx| 亚洲国产美女精品久久久久∴| 国产亚洲毛片在线| 久久青草福利网站| 嫩草国产精品入口| 99re热这里只有精品免费视频| 久久精品91久久久久久再现| 亚洲欧美中文另类| 国产精品毛片va一区二区三区| 一本色道久久88综合日韩精品| 国产九九精品视频| 一区二区三区精品| 亚洲最新中文字幕| 欧美日韩日本国产亚洲在线| 一本色道久久精品| 亚洲欧美日韩在线一区| 国产精品高潮在线| 亚洲欧美电影院| 午夜天堂精品久久久久 | 亚洲天堂第二页| 亚洲综合视频一区| 国产精品视频在线观看| 香蕉免费一区二区三区在线观看 | 久久免费黄色| 亚洲电影在线免费观看| 亚洲精品午夜| 伊人久久噜噜噜躁狠狠躁| 亚洲国产专区| 亚洲一区视频| 国产一区二区三区免费观看| 午夜视频久久久久久| 亚洲欧美日韩精品一区二区| 亚洲电影av| 欧美日韩美女一区二区| 久久精品国产免费看久久精品 | 亚洲三级电影在线观看| 欧美在线日韩|