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

勤能補拙,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 閱讀(2057) 評論(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>
            免费成人在线观看视频| 亚洲亚洲精品在线观看| 欧美一级成年大片在线观看| 欧美与欧洲交xxxx免费观看| 美女脱光内衣内裤视频久久网站| 欧美激情第三页| 久久精品动漫| 久久久国产精品一区二区三区| 亚洲高清不卡在线观看| 在线综合亚洲欧美在线视频| 午夜精品一区二区在线观看| 欧美超级免费视 在线| 亚洲精品影院| 国产精品美女一区二区| 国产日韩综合| 在线精品观看| 久久久久一区二区| 亚洲欧美视频| 国产精品久久网站| 亚洲资源av| 亚洲精品激情| 欧美黄色一区二区| 一区二区福利| aa国产精品| 欧美视频专区一二在线观看| 国产精品99久久久久久久vr| avtt综合网| 国产精品都在这里| 亚洲欧美资源在线| 欧美在线视频免费播放| 国内精品伊人久久久久av一坑| 久久久99国产精品免费| 久久精品30| 亚洲黄色高清| 日韩午夜免费| 国产模特精品视频久久久久| 久久久久久久久久久成人| 久久精品亚洲| 亚洲精品在线免费| 国产精品99久久久久久白浆小说| 国产精品午夜视频| 久久亚洲视频| 欧美激情亚洲国产| 亚洲在线观看视频| 久久精品一区中文字幕| 亚洲精品免费网站| 亚洲一区二区在线视频| 激情久久五月| 日韩视频免费观看高清完整版| 国产精品婷婷午夜在线观看| 久热精品在线视频| 欧美劲爆第一页| 久久精品99久久香蕉国产色戒| 免费视频一区| 午夜欧美电影在线观看| 久久综合中文色婷婷| 亚洲欧美国内爽妇网| 久热精品在线视频| 亚洲欧美国产日韩中文字幕| 久久躁日日躁aaaaxxxx| 亚洲一级片在线观看| 久久免费国产| 欧美日韩一区二区三区在线看| 久久久久久久国产| 国产在线不卡视频| 免费91麻豆精品国产自产在线观看| 久久字幕精品一区| 日韩一区二区久久| 国产日韩欧美在线观看| 久久久国产精品一区| 久久久久久久网| 欧美极品色图| 久热精品在线视频| 国产女人水真多18毛片18精品视频| 嫩模写真一区二区三区三州| 国产精品黄页免费高清在线观看| 欧美大胆a视频| 国产日韩一区二区| 日韩亚洲在线观看| 亚洲欧洲日产国产综合网| 欧美一区网站| 欧美一区二区久久久| 欧美日韩激情网| 亚洲国产你懂的| 精品动漫一区| 欧美亚洲在线| 欧美在线观看视频一区二区| 欧美三级在线| 一本久久综合亚洲鲁鲁五月天| 日韩视频国产视频| 欧美高清在线视频| 亚洲黄色大片| 亚洲精品一区在线| 免费观看亚洲视频大全| 蘑菇福利视频一区播放| 悠悠资源网久久精品| 久久精品国产96久久久香蕉| 久久国产精品毛片| 国产香蕉久久精品综合网| 午夜精品福利电影| 久久精品一级爱片| 狠狠色狠狠色综合人人| 先锋影音网一区二区| 久久精品国产久精国产一老狼 | 午夜精品www| 亚洲欧洲av一区二区三区久久| 老司机午夜精品视频在线观看| 欧美亚洲综合久久| 国产精品jizz在线观看美国| 99伊人成综合| 亚洲欧美日韩精品久久奇米色影视 | 亚洲无人区一区| 国产精品白丝av嫩草影院| 日韩亚洲欧美综合| 性做久久久久久| 国产亚洲一区二区三区在线观看 | 欧美大香线蕉线伊人久久国产精品| 国产在线精品一区二区中文 | 国产精品久久久一区二区| 亚洲一区bb| 亚洲欧美在线视频观看| 国产一区二区精品| 浪潮色综合久久天堂| 亚洲欧洲精品成人久久奇米网| 中文精品一区二区三区| 国产精品每日更新| 久久久久国产精品一区| 亚洲国产一区二区三区高清 | 亚洲九九九在线观看| 亚洲欧美日本国产专区一区| 国产一区日韩一区| 欧美gay视频| 亚洲午夜成aⅴ人片| 久久久久久网| 亚洲午夜久久久久久久久电影院 | 99re热这里只有精品免费视频| 亚洲一区二区三区中文字幕在线| 国产精品日韩久久久久| 久久一区二区三区超碰国产精品| 亚洲国产精选| 欧美一区国产在线| 亚洲国产日韩一区二区| 国产精品婷婷| 欧美精品九九99久久| 亚洲一级黄色片| 亚洲精品乱码久久久久久按摩观 | 在线亚洲伦理| 欧美国产另类| 欧美一区二区三区免费视频| 亚洲精品中文字幕女同| 国产午夜精品全部视频播放| 欧美日本亚洲| 久久久久在线| 亚洲免费综合| 亚洲麻豆视频| 欧美激情一区二区在线| 久久久噜久噜久久综合| 亚洲欧美日韩国产中文在线| 日韩视频一区二区三区| 激情亚洲网站| 国产一区二区三区四区老人| 国产精品久久久99| 欧美精品aa| 欧美aa在线视频| 免费在线国产精品| 久久综合久久综合久久| 久久精品亚洲| 久久精品成人| 午夜国产精品影院在线观看| av成人黄色| 亚洲精品国产精品国自产观看 | 久久精品国产第一区二区三区最新章节 | 国产一区二区视频在线观看| 久久视频在线视频| 麻豆精品网站| 亚洲欧美日韩天堂| 欧美成人精品不卡视频在线观看| 欧美成人在线影院| 国产欧美一区二区三区另类精品| 久久久蜜桃一区二区人| 欧美一级在线播放| 午夜精品一区二区在线观看| 亚洲欧美在线一区| 亚洲欧美日本另类| 亚洲欧美日韩中文播放| 亚洲欧美综合v| 性高湖久久久久久久久| 欧美一级视频一区二区| 午夜亚洲性色视频| 久久福利一区| 久久性天堂网| 欧美多人爱爱视频网站| 欧美激情精品久久久久久免费印度| 欧美 日韩 国产 一区| 欧美成人免费播放| 欧美日韩亚洲综合| 国产精品丝袜91| 在线观看日韩一区| 亚洲免费观看高清在线观看 | 亚洲国产精品尤物yw在线观看 |