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

勤能補拙,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>
            亚洲美女中文字幕| 亚洲高清久久| 午夜精品亚洲| 国产午夜亚洲精品羞羞网站| 久久精品亚洲精品国产欧美kt∨| 欧美一区2区视频在线观看| 国产综合久久久久久| 媚黑女一区二区| 久久久久成人精品| 亚洲欧洲日本在线| 日韩视频一区二区在线观看| 国产精品社区| 欧美xart系列高清| 欧美色123| 老司机免费视频一区二区| 老色批av在线精品| 亚洲在线观看视频网站| 久久精品成人一区二区三区| 99精品视频免费观看| 亚洲一区在线直播| 91久久精品国产91久久| 亚洲视频在线二区| 亚洲欧洲日本专区| 欧美一二三区精品| av成人毛片| 欧美一级二区| av不卡在线观看| 久久精品成人一区二区三区| 亚洲小说区图片区| 久久婷婷影院| 欧美一级精品大片| 欧美日韩999| 欧美成人性网| 国内成人精品2018免费看 | 99精品99| 在线免费高清一区二区三区| 99综合精品| 在线观看日韩| 国产精品99久久久久久有的能看| 亚洲成在人线av| 欧美一区二区播放| 亚洲一区二区三区四区五区午夜 | 99riav1国产精品视频| 韩曰欧美视频免费观看| 亚洲综合精品一区二区| 亚洲美女视频在线观看| 久久婷婷久久| 久久另类ts人妖一区二区| 国产精品久久久久久久久免费桃花 | 亚洲精品一区在线| 久久久久成人网| 久久人人九九| 国产欧美日韩免费| 亚洲——在线| 午夜精品999| 国产精品久久久久久久久免费桃花| 亚洲国产精品成人va在线观看| 精品福利av| 久久精品午夜| 欧美mv日韩mv亚洲| 亚洲国产小视频在线观看| 久久在线免费观看视频| 久久综合导航| 亚洲国产va精品久久久不卡综合| 久久久久成人精品| 欧美成人激情在线| 亚洲激情成人在线| 欧美国产日韩一区二区三区| 亚洲黄色一区二区三区| 日韩亚洲一区在线播放| 欧美日韩一区二区三区四区五区| 亚洲乱码国产乱码精品精天堂| 99av国产精品欲麻豆| 欧美日韩精品在线观看| 在线视频中文亚洲| 久久精品夜色噜噜亚洲a∨| 国产一区日韩二区欧美三区| 久久免费精品视频| 亚洲国产精品尤物yw在线观看 | 国产美女精品一区二区三区| 亚洲欧美日韩一区| 开心色5月久久精品| 亚洲欧洲综合另类| 国产精品二区在线观看| 欧美一区二区视频97| 麻豆成人在线| 夜夜精品视频一区二区| 国产精品一区二区男女羞羞无遮挡 | 欧美在线三区| 影音先锋亚洲精品| 欧美区在线观看| 亚洲女女女同性video| 久热精品视频在线免费观看| 亚洲九九爱视频| 亚洲在线国产日韩欧美| 亚洲国产欧美国产综合一区| 欧美日本成人| 亚洲欧美在线视频观看| 欧美激情无毛| 欧美一区高清| 99精品国产高清一区二区| 国产欧美一区二区视频| 农夫在线精品视频免费观看| 亚洲在线观看免费视频| 亚洲国产cao| 久久久中精品2020中文| 亚洲视频视频在线| 在线观看亚洲一区| 国产精品亚洲综合| 欧美剧在线观看| 久久久一二三| 亚洲一区www| 亚洲人成人一区二区三区| 久久精品国产96久久久香蕉 | 国产精品卡一卡二| 欧美国产在线电影| 欧美在线视频在线播放完整版免费观看 | 蜜臀av国产精品久久久久| 亚洲午夜久久久久久久久电影院 | 欧美一区二区三区啪啪| 日韩一区二区久久| 亚洲激情自拍| 亚洲国产精品激情在线观看| 久久久久久久久久久久久女国产乱 | 午夜精品国产更新| 日韩天堂在线视频| 亚洲国产高清aⅴ视频| 久久久蜜臀国产一区二区| 性欧美xxxx大乳国产app| 99伊人成综合| 亚洲乱码国产乱码精品精天堂| 伊人影院久久| 一区在线免费| 激情久久五月天| 国模精品一区二区三区色天香| 国产精品嫩草影院av蜜臀| 欧美日韩精品一二三区| 欧美激情国产日韩| 欧美激情精品久久久久久黑人 | 亚洲一区二区不卡免费| 亚洲最新色图| 一区二区三区日韩| 亚洲一区中文| 欧美一区二区| 久久深夜福利| 欧美aaa级| 欧美精品色一区二区三区| 欧美激情在线狂野欧美精品| 欧美女同视频| 国产精品美女久久福利网站| 国产精品区一区| 国产日韩欧美日韩| 黑人巨大精品欧美黑白配亚洲| 亚洲最新视频在线| 亚洲欧洲另类国产综合| 欧美成人一区二区| 亚洲第一区色| 亚洲精品在线免费| 亚洲一区二区在线观看视频| 午夜日韩激情| 久久综合九色| 欧美日韩精品免费看| 国产精品亚洲不卡a| 国产原创一区二区| 亚洲欧洲另类| 亚洲欧美国产精品桃花| 久久精品国产久精国产思思| 欧美二区在线观看| 99精品国产福利在线观看免费| 亚洲一区中文| 男人的天堂成人在线| 欧美色一级片| 亚洲国产老妈| 午夜久久资源| 亚洲电影在线看| 亚洲欧洲99久久| 欧美精品免费播放| 国产欧美一区二区三区久久| 永久免费毛片在线播放不卡| 日韩网站在线观看| 久久久久久9999| 亚洲伦理在线| 老牛影视一区二区三区| 国产精品美腿一区在线看| 最新成人在线| 久久久久久日产精品| 99re66热这里只有精品4| 久久精品国产欧美激情| 欧美三级电影大全| 亚洲人成网站777色婷婷| 久久精品卡一| 一区二区三欧美| 欧美jizz19性欧美| 国内成人精品一区| 亚洲男人的天堂在线aⅴ视频| 欧美激情一区二区三区在线 | 欧美成人乱码一区二区三区| 亚洲欧美高清| 国产精品国产三级国产专播品爱网| 亚洲欧洲久久|