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

勤能補(bǔ)拙,Expter

成都游戲Coder,記錄游戲開(kāi)發(fā)過(guò)程的筆記和心得!

一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法

        問(wèn)題描述如下:
                2個(gè)整數(shù)(int32),我需要對(duì)這2個(gè)數(shù)的第n位進(jìn)行二進(jìn)制數(shù)交換值。是否有一個(gè)高效的算法,或者高效的運(yùn)算。

                例子如下:

                2個(gè)整數(shù)10,7,把第1位的數(shù)值交換。

               整數(shù)          二進(jìn)制        交換后二進(jìn)制       交換后的值

                10             0x1010        0x1011                   11

                7               0x0111        0x0110                   6

               

             我的思路如下:

              1.如果要對(duì)第n位數(shù)值交換,先求出第n位的值(1或者0),如果相等則不交換。

              2.交換第n位,通過(guò)通過(guò)原理發(fā)現(xiàn)只需通過(guò)加減法運(yù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}

 

           是否有一種高效的算法,只是進(jìn)行一,兩步位與或運(yùn)算即可。。

        

posted on 2009-10-18 22:27 expter 閱讀(2069) 評(píng)論(13)  編輯 收藏 引用 所屬分類: 其他學(xué)習(xí)筆記工作筆記算法與數(shù)據(jù)結(jié)構(gòu)

評(píng)論

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法[未登錄](méi) 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;
}
}  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法 2009-10-18 23:56 夜風(fēng)

你這個(gè)算法有很多是多余的,而且位運(yùn)算就少用+、-,看看下面的算法,感覺(jué)不錯(cuò)哦
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;
}  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法 2009-10-19 00:19 lucifer

可以不需要if判斷語(yǔ)句的,
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;
}  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法 2009-10-19 09:09 Fox

支持@Eric
  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法[未登錄](méi) 2009-10-19 10:23 alex-lee

Eric算法好  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(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)吧  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法 2009-10-19 14:55 淘寶皇冠店

感覺(jué)不錯(cuò)哦  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法[未登錄](méi) 2009-10-19 16:58 vincent

eric  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法[未登錄](méi) 2009-10-19 17:29 goteet

& | 是基本把  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法[未登錄](méi) 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;
}  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法 2009-10-19 20:26 expter

@Eric
@wangjinhu
的方法不錯(cuò),學(xué)習(xí)了。。。  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法 2009-10-21 12:59 阿福

我有一種辦法,應(yīng)該是最快的:
把顯示器倒過(guò)來(lái),哈哈!  回復(fù)  更多評(píng)論   

# re: 一個(gè)問(wèn)題,如何優(yōu)化? 是否有高效的算法 2009-10-22 09:29 李佳

樓上很風(fēng)趣   回復(fù)  更多評(píng)論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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乱码| 一区二区在线免费观看| 久久精品91久久香蕉加勒比| 麻豆成人在线| 亚洲美女尤物影院| 欧美香蕉视频| 久久精品国产久精国产爱| 欧美福利视频| 亚洲免费影视| 久久人体大胆视频| 91久久在线观看| 亚洲欧美资源在线| 亚洲图片自拍偷拍| 欧美女激情福利| 欧美一级夜夜爽| 亚洲黄色成人久久久| 欧美 日韩 国产精品免费观看| 欧美亚洲免费高清在线观看| 激情五月综合色婷婷一区二区| 欧美极品一区| 午夜精品久久一牛影视| 亚洲黄色一区二区三区| 香蕉久久国产| 亚洲乱码国产乱码精品精98午夜| 国产精品系列在线| 欧美大尺度在线| 性久久久久久久| 亚洲另类黄色| 免费av成人在线| 欧美亚洲综合另类| 99在线精品观看| 精品二区视频| 欧美一区二区黄色| 亚洲精品一区二区三区99| 久久色在线播放| 午夜精品久久| 日韩一级成人av| 在线观看亚洲一区| 国产美女高潮久久白浆| 久热精品视频在线观看| 国内精品久久久久久久果冻传媒| 欧美区视频在线观看| 久久深夜福利| 欧美一区二区三区在线观看| 免费成人av资源网| 亚洲永久精品国产| 99re66热这里只有精品4| 欧美丰满高潮xxxx喷水动漫| 欧美在线欧美在线| 亚洲欧美韩国| 亚洲视频一区在线| 99热这里只有成人精品国产| 亚洲国产成人久久| 伊人色综合久久天天| 国产欧美日本在线| 国产精品三级久久久久久电影| 9色精品在线| 日韩一二在线观看| 亚洲欧洲精品一区| 亚洲福利国产精品| 欧美国产欧美亚州国产日韩mv天天看完整| 久久久www成人免费精品| 欧美一区中文字幕| 女同一区二区| 99国产精品久久久| 99视频一区| 一区二区三区日韩欧美精品| 亚洲免费不卡| 亚洲社区在线观看| 亚洲一区二区在线视频| 亚洲网站视频| 亚洲欧美自拍偷拍| 性欧美1819sex性高清| 香蕉久久夜色精品| 久久激情视频| 免费成人av在线| 欧美激情亚洲精品| 国产精品v片在线观看不卡| 久久天堂av综合合色| 激情综合激情| 亚洲三级免费电影| 牛牛精品成人免费视频| 欧美日韩亚洲一区二区三区| 欧美精品一区三区| 在线播放日韩专区| 亚洲高清视频在线观看| 亚洲人成网站色ww在线| 亚洲精品韩国| 亚洲一区二区免费| 久久99伊人| 欧美成人精品在线播放| 亚洲黄色免费电影| 在线亚洲精品| 久久精品国产亚洲5555| 亚洲美女黄色片| 亚洲精品小视频在线观看| 一本一本大道香蕉久在线精品| 亚洲一区二区成人在线观看| 欧美在线免费视屏| 欧美成人蜜桃| 一区二区三区免费在线观看| 欧美一区二区三区啪啪| 欧美高清视频免费观看| 国产精品久久影院| 亚洲第一毛片| 亚洲欧美精品在线| 美女主播一区| 中文精品视频一区二区在线观看| 欧美一区二区视频97| 欧美国产日本| 国模吧视频一区| 国产精品美女主播| 亚洲福利视频在线| 性久久久久久久久久久久| 免费日韩一区二区| 亚洲夜间福利| 欧美夫妇交换俱乐部在线观看| 国产精品一二一区| 日韩系列欧美系列| 久久人人97超碰国产公开结果| 亚洲大片在线| 亚洲二区免费| 欧美一区视频| 国产精品综合色区在线观看| 欧美日本一道本| 激情亚洲网站| 欧美在线播放一区| 亚洲免费精彩视频| 蜜桃av综合| 国产一区二区三区自拍| 亚洲免费在线精品一区| 亚洲激情精品| 久久久久久久波多野高潮日日| 国产精品高清网站| 亚洲免费精品| 欧美黄色一区| 久久久久九九九九| 国产亚洲一区二区三区在线播放| 亚洲视频欧美视频| 亚洲黄色av一区| 亚洲黄色成人久久久| 久久在线视频| 在线观看久久av| 久久久爽爽爽美女图片| 亚洲欧美日韩另类| 国产精品区二区三区日本| 亚洲免费成人| 亚洲国产激情| 欧美大片免费久久精品三p| 欧美成人自拍| 久久福利毛片| 黄色成人精品网站| 久久精品人人做人人爽| 亚洲欧美日韩在线观看a三区| 欧美亚韩一区| 亚洲一区精品在线| 亚洲视频精选在线| 国产精品第三页| 亚洲在线观看视频网站| 一本色道久久综合狠狠躁篇怎么玩 | 国产精品一区在线观看| 国产日韩欧美日韩大片| 欧美一区二区黄色| 亚洲综合日本| 国产欧美日韩一区二区三区在线| 亚洲综合不卡| 亚洲婷婷综合色高清在线| 欧美三级特黄| 午夜精品在线看| 欧美亚洲一区二区三区| 亚洲毛片一区| 免费亚洲电影| 99精品热6080yy久久| 日韩午夜av电影| 国产精品美女www爽爽爽视频| 午夜精品短视频| 久久gogo国模裸体人体| 亚洲承认在线| 最新日韩av| 国产精品日韩二区| 久久乐国产精品| 久久综合久久综合九色| 亚洲美女尤物影院| 亚洲一区二区三区在线播放| 国产婷婷色一区二区三区四区| 久久久蜜桃一区二区人| 免费黄网站欧美| 亚洲天堂网在线观看| 亚洲欧美色一区| 亚洲国产欧美日韩另类综合| 亚洲人成小说网站色在线 | 中文在线资源观看视频网站免费不卡| 欧美日韩国产123区| 午夜精品三级视频福利| 久久久久国产精品厨房| 99视频精品全部免费在线| 欧美成人中文|