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

勤能補拙,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>
            欧美二区在线| 欧美午夜剧场| 一本久道久久综合狠狠爱| 嫩草国产精品入口| 欧美国产欧美综合| 欧美国产先锋| 一本久久a久久免费精品不卡| 一本色道久久综合亚洲精品高清 | 在线成人av.com| 亚洲激情成人| 亚洲性感激情| 久久久另类综合| 欧美成人精品在线观看| 亚洲精品四区| 午夜视频一区| 模特精品在线| 国产精品色一区二区三区| 国产一区二区中文字幕免费看| 伊人春色精品| 欧美一区激情| 嫩草伊人久久精品少妇av杨幂| 亚洲福利视频一区| 亚洲黄网站在线观看| 亚洲图中文字幕| 久久夜色精品国产欧美乱极品| 欧美日韩不卡合集视频| 国产麻豆精品视频| 艳女tv在线观看国产一区| 久久精品毛片| 99国产麻豆精品| 久久综合给合| 国产欧美日韩免费| 中文精品视频一区二区在线观看| 久久最新视频| 亚洲永久在线| 欧美日韩精品| 亚洲欧洲三级| 久久一二三区| 午夜精品亚洲一区二区三区嫩草| 欧美日韩1区2区| 精品福利电影| 久久精品欧美日韩| 亚洲一区二区三| 欧美日韩中文另类| 亚洲精品一区在线观看| 美腿丝袜亚洲色图| 久久国产66| 国产色视频一区| 午夜精品av| 在线视频精品一| 欧美午夜一区二区福利视频| 一本色道88久久加勒比精品| 欧美激情亚洲精品| 欧美+亚洲+精品+三区| 1000部精品久久久久久久久| 久久精品国产精品亚洲精品| 亚洲在线免费视频| 国产精品网站在线播放| 午夜在线电影亚洲一区| 亚洲一区二区免费| 国产精品一区二区黑丝| 欧美一区二区三区视频| 亚洲欧美一级二级三级| 国产欧美日韩91| 久久久久久欧美| 久久国产视频网站| 在线播放国产一区中文字幕剧情欧美| 久久久久久久激情视频| 久久亚洲美女| 亚洲美女诱惑| 这里是久久伊人| 国产欧美不卡| 免费成人美女女| 欧美激情a∨在线视频播放| 亚洲乱码国产乱码精品精| 日韩亚洲视频在线| 国产精品久久久久婷婷| 久久xxxx精品视频| 久久久久国产成人精品亚洲午夜| 久久免费国产精品| 欧美精品三级日韩久久| 日韩一级免费观看| 亚洲视频二区| 激情久久五月天| 91久久精品美女| 国产精品久久久99| 免费观看一区| 欧美午夜激情在线| 久久蜜桃香蕉精品一区二区三区| 另类亚洲自拍| 亚洲尤物精选| 久久久久www| 一区二区三区高清视频在线观看| 一区二区三区偷拍| 在线成人激情视频| 一本色道久久综合亚洲精品高清| 国产一区二区三区的电影| 亚洲高清视频在线观看| 国产精品手机在线| 欧美激情欧美激情在线五月| 国产精品久久久久久一区二区三区| 久久三级福利| 国产精品久久国产愉拍| 欧美xx视频| 国产欧美精品一区二区色综合 | 欧美精品黄色| 久久久久久久久一区二区| 欧美久久久久久久久| 久久久欧美精品sm网站| 欧美色道久久88综合亚洲精品| 麻豆免费精品视频| 国产精品一区二区三区久久久| 亚洲夫妻自拍| 韩国福利一区| 亚洲欧美日韩精品一区二区 | 欧美在线综合视频| 亚洲自啪免费| 欧美日韩xxxxx| 亚洲激情图片小说视频| 在线成人av.com| 久久不射网站| 欧美中在线观看| 国产精品系列在线播放| 99精品国产在热久久| 日韩视频在线免费| 欧美电影在线播放| 亚洲第一区在线| 亚洲国产高清aⅴ视频| 久久精品国产69国产精品亚洲| 欧美在线看片| 国产情人节一区| 午夜精品999| 性欧美8khd高清极品| 国产精品乱码| 一本色道久久精品| 亚洲已满18点击进入久久| 欧美日本中文字幕| 一本色道久久99精品综合| 中文亚洲欧美| 久久久精品一区二区三区| 久久精品国产在热久久| 欧美亚洲三级| 国产欧美日韩精品在线| 亚洲尤物视频网| 午夜视黄欧洲亚洲| 国产日韩欧美在线播放| 欧美在线综合| 女人香蕉久久**毛片精品| 亚洲高清在线精品| 欧美精品久久久久久| 亚洲精品影视| 亚洲欧美日韩在线播放| 国产视频精品va久久久久久| 久久久国产精彩视频美女艺术照福利 | 亚洲午夜在线观看视频在线| 性欧美xxxx视频在线观看| 国产欧美精品一区aⅴ影院| 欧美一级大片在线观看| 两个人的视频www国产精品| 亚洲第一视频| 欧美日韩午夜剧场| 亚洲尤物在线| 免费亚洲视频| 一区二区三区四区五区视频| 国产精品区一区二区三| 久久精品国产精品亚洲精品| 欧美激情国产日韩| 亚洲一区二区三区在线看 | 欧美日韩卡一卡二| 亚洲在线免费观看| 欧美国产欧美综合| 亚洲欧美激情在线视频| 在线播放日韩专区| 欧美视频在线观看| 久久精品国产99精品国产亚洲性色| 欧美成人国产一区二区| 亚洲天堂av在线免费观看| 国产综合欧美| 欧美日韩三级| 久久人人爽爽爽人久久久| av不卡在线观看| 欧美成人免费全部| 欧美一区二区三区成人| 亚洲久久在线| 狠狠久久五月精品中文字幕| 欧美日韩免费观看一区| 久久阴道视频| 欧美一级大片在线免费观看| 99热精品在线| 亚洲国产一区二区三区a毛片| 久久er99精品| 性欧美1819sex性高清| 国产精品99久久99久久久二8 | 亚洲精品日本| 黄色资源网久久资源365| 国产精品初高中精品久久| 欧美高清不卡在线| 久久美女性网| 久久久91精品| 欧美制服丝袜|