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

雁過無痕

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::

    Trilogy公司的筆試題:

如果n為偶數(shù),則將它除以2,如果n為奇數(shù),則將它加1或者減1。問對于一個給定的n,怎樣才能用最少的步驟將它變到1
    例如:n=11: ① ++n -> 12 ② n/2 -> 6 ③ n/2 -> 3   ④ --n -> 2  ⑤ n/2 -> 1  共需5步。

 
 

最簡單的方法就是用DP。設(shè)f(n)為所用的最少步驟。根據(jù)定義可得:

n為偶數(shù), f(n)=f(n/2) + 1;

n為奇數(shù), f(n)= min(f(n-1), f(n+1)) +1

                       = min(f((n-1)/2), f((n+1)/2)) +2

或者:

 f(2*k)=f(k)+1 

f(2*k+1)=min(f(k),f(k+1))+2

 

利用上述遞推公式,可以直接從數(shù)字1開始算到n,用一個數(shù)組保存前 n/2+1個數(shù)所用的最少步驟,但這時間和空間復雜度均為O(n),其實利用上面的遞推公式,可以實現(xiàn)時間復雜度為0(lg n)。觀察上面的遞推公式,可以發(fā)現(xiàn),要計算n,只要計算n/2n/2+1,如要計算59,只要計算:

59 -> 29,30 -> 14,15 -> 7,8 -> 3,4 -> 1,2

 

代碼如下:

int num2one_dp(unsigned n)
{
  unsigned tmp
=n, flag=1, ret=0, next=1;
  
while (tmp>>=1) flag<<=1;
  
while (flag>>=1{
    
if (n & flag) {
      
if (ret > next) ret = next;
      ret 
+= 2;
      
++next;
    }
 else {
      
if (next > ret) next = ret;
      next 
+= 2;
      
++ret;
    }

  }

  
return ret;
}


上面的O(lg n)解法,對n先處理高位的01,下面的O(lg n)解法則恰恰相反,先處理n的低位的01

nn>1)轉(zhuǎn)為二進制數(shù)表示

(下面的“加1”、“減1”操作均特指對奇數(shù)采取的操作,操作次數(shù)包括對偶數(shù)的操作次數(shù)。)

⑴ 如果n僅由m個連續(xù)的1組成(即n=2^m-1 m>=2),

① “加1”操作:  需要 m+1 次操作

② “減1”操作:  需要 2*(m-1) 次操作

       顯然,僅當m=2(即n=3)時,“減1”所用的操作次數(shù)才比1”少。

⑵ 如果n可以表示為:x10m1k m>=1, k>=1

x可以為空串或任意01序列,0m表示連續(xù)m01k表示連續(xù)k1)

   ① “加1”操作:  k+1 次操作后得到x10m-11如果,接著用“減1”操作(注意,這不這一定最優(yōu)解法),總共k+3次操作可得x10m-1

   ②“減1”操作:  2*k+1次操作后得到x10m-1

   顯然,僅當k=1時,“減1”所用的操作次數(shù)才可能比1”少。

   可以證明,對x10m1,“減1”所用的操作次數(shù)一定不會比“加1”的多。

   (當k=1時,對x10m1,假設(shè)先進行一次“加1”操作最終所用的步驟數(shù)較少。“加1”操作后,在將x10m1轉(zhuǎn)為x11前,若用到“減1”操作,則可以直接對x10m1進行 “減1”操作,所有步驟更少,因而后面都是采用“加1”操作。

     x10m1(可表示為y01t0m1y允許是空串),

 “加1”操作   2*m+t+2 次后得到  y1

“減1”操作       m+2 次后得到  y01t

(再用“加1操作”,m+t+3后也可得到y1

由于對m>=1,恒有m+t+3 <= 2*m+t+2,因而對x10m1

“減1”操作能保證得到最優(yōu)解。)

⑶ 總之,僅當n=3n二進制表示的最低2位是01時,才用“減1”操作


代碼:

int num2one(unsigned n)
{
  
if (n==0return -1;
  
int count=0;
  
while (1{
    
while ((n&1)==0{ n >>= 1u++count; }
    
if (n<=3{
      
// n只能為1或3,n為3時,還要進行兩步操作
      count += n - 1;
      
break;
    }

    
if ((n&3)==1)  --n;
    
else ++n;
    
++count;
  }

  
return count;
}


 

posted on 2010-06-21 12:46 flyinghearts 閱讀(2221) 評論(5)  編輯 收藏 引用 所屬分類: 算法

評論

# re: Trilogy公司的筆試題:用最少的步驟將數(shù)轉(zhuǎn)為1 2010-06-21 17:45 刀刀
題目看不明白  回復  更多評論
  

# re: Trilogy公司的筆試題:用最少的步驟將數(shù)轉(zhuǎn)為1 2010-06-21 18:31 唐風
確實題目不清楚。呵呵
  回復  更多評論
  

# re: Trilogy公司的筆試題:用最少的步驟將數(shù)轉(zhuǎn)為1 2010-06-21 19:40 小時候可靚了
n &= 0x1;
或者
n = 1;  回復  更多評論
  

# re: Trilogy公司的筆試題:根據(jù)指定規(guī)則用最少的步驟將數(shù)轉(zhuǎn)為1 2010-06-22 00:07 flyinghearts
題目已經(jīng)改過來了。
  回復  更多評論
  

# re: Trilogy公司的筆試題:根據(jù)指定規(guī)則用最少的步驟將數(shù)轉(zhuǎn)為1 2010-06-22 09:05 凡客誠品官方網(wǎng)站
Trilogy公司的筆試題  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品午夜| 国产亚洲福利| 毛片基地黄久久久久久天堂| 亚洲欧美成人一区二区三区| 国产精品乱码一区二区三区 | 欧美精品一区在线观看| 国产情人节一区| 欧美国产日韩视频| 国产主播在线一区| 蜜臀久久99精品久久久久久9 | 国产精品一二一区| 亚洲乱码国产乱码精品精| 9人人澡人人爽人人精品| 亚洲成人资源网| 欧美成人免费在线观看| 久久激情婷婷| 欧美专区第一页| 欧美成人自拍| 欧美一二区视频| 国产伦精品一区二区三区照片91| 亚洲一区二区三区中文字幕在线| 免费不卡在线观看| 久久一区二区三区超碰国产精品| 性色av一区二区三区在线观看| 最新国产拍偷乱拍精品 | 亚洲美女91| 性欧美videos另类喷潮| 红桃视频成人| 麻豆精品91| 亚洲自拍偷拍一区| 欧美成人精品福利| 久久久久国产一区二区三区| 欧美福利电影在线观看| 久久午夜av| 欧美激情成人在线视频| 亚洲黄一区二区三区| 欧美日韩亚洲精品内裤| 亚洲成色777777女色窝| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲精品1区| 欧美亚洲专区| 欧美精品久久久久久| 91久久精品国产91久久性色| 亚洲性视频网址| 久久一区欧美| 亚洲激情在线| 亚洲深夜av| 国产精品乱码妇女bbbb| 亚洲一区国产一区| 99re6热只有精品免费观看| 亚洲午夜羞羞片| 国产精品毛片va一区二区三区 | 亚洲视频导航| 在线综合亚洲欧美在线视频| 你懂的网址国产 欧美| 99国产精品视频免费观看一公开| 香蕉视频成人在线观看 | 麻豆成人小视频| 亚洲欧美日韩一区二区三区在线| 亚洲欧美欧美一区二区三区| 午夜国产精品视频| 亚洲欧美网站| 午夜一区不卡| 欧美在线黄色| 久久久五月天| 国产精品美女久久福利网站| 欧美护士18xxxxhd| 久久精品网址| 欧美日韩亚洲另类| 国产一区二区在线观看免费播放| 狠狠色香婷婷久久亚洲精品| 亚洲天堂免费观看| 一区二区在线观看av| 国产亚洲精品久| 国产欧美日韩激情| 国产精品一区二区三区成人| 欧美人牲a欧美精品| 欧美日韩国产在线播放| 久久精品视频免费| 亚洲欧美www| 欧美日韩中文字幕日韩欧美| 激情综合网址| 猫咪成人在线观看| 欧美成人国产一区二区| 一区精品久久| 欧美成人免费网| 欧美日韩国产三区| 亚洲欧美日韩天堂| 久久狠狠婷婷| 亚洲精品综合久久中文字幕| 亚洲肉体裸体xxxx137| 欧美日韩国产综合网| 亚洲欧美国产毛片在线| 久久久人成影片一区二区三区观看| 久久不射中文字幕| 激情国产一区| 亚洲成色999久久网站| 欧美精品日韩一本| 亚洲欧美日韩综合| 欧美中文在线观看国产| 亚洲激情小视频| 一区二区激情视频| 国产欧美日韩一区二区三区在线| 久久久久网址| 欧美日韩精品欧美日韩精品| 欧美中文字幕视频| 久久久亚洲影院你懂的| 亚洲精品亚洲人成人网| 亚洲午夜在线| 一区二区视频欧美| 亚洲婷婷综合色高清在线| 国产一区久久| 99国内精品久久| 激情综合色丁香一区二区| 最新国产乱人伦偷精品免费网站| 国产精品推荐精品| 亚洲国产国产亚洲一二三| 国产在线精品自拍| 99热在线精品观看| 激情久久久久久久| 99视频有精品| 亚洲伦理在线| 久久精品理论片| 夜夜嗨av一区二区三区中文字幕| 欧美主播一区二区三区美女 久久精品人 | 欧美中文在线免费| 中文久久精品| 可以看av的网站久久看| 午夜激情久久久| 欧美精品亚洲一区二区在线播放| 美女主播一区| 一区免费观看视频| 久久久高清一区二区三区| 久久av一区二区| 国产伦精品一区二区三区视频孕妇| 日韩视频在线观看| 一本综合精品| 欧美日韩在线视频一区二区| 亚洲激情社区| 日韩视频永久免费| 欧美精品午夜| 一区二区三区**美女毛片| 一区二区三区不卡视频在线观看 | 欧美成人久久| 欧美国产成人精品| 亚洲国内在线| 欧美精品久久天天躁 | 久久精品免费电影| 久久精品夜色噜噜亚洲a∨| 国产精品视频一| 小黄鸭精品aⅴ导航网站入口| 欧美一区二区三区日韩视频| 亚洲一区网站| 久久久午夜电影| 国产精品入口麻豆原神| 好吊色欧美一区二区三区视频| 欧美久久视频| 亚洲视频导航| 老色批av在线精品| 欧美激情在线狂野欧美精品| 亚洲欧洲精品天堂一级 | 久久精品中文字幕一区| 国产一区欧美日韩| 麻豆av福利av久久av| 亚洲国产中文字幕在线观看| 99精品国产在热久久婷婷| 欧美日韩在线影院| 香蕉成人啪国产精品视频综合网| 久久激情五月婷婷| 伊人狠狠色丁香综合尤物| 蜜臀a∨国产成人精品| 99视频一区二区三区| 欧美一区91| 亚洲国产精品高清久久久| 欧美人成免费网站| 午夜在线一区二区| 欧美国产综合视频| 欧美大学生性色视频| 国产精品美女在线| 亚洲精品日产精品乱码不卡| 一区二区三区高清| 99国产精品99久久久久久| 亚洲欧美日韩在线播放| 国产在线视频欧美一区二区三区| 欧美成人一品| 午夜亚洲伦理| 亚洲激情视频网站| 久久九九全国免费精品观看| 亚洲区一区二| 国产精品欧美激情| 欧美韩国一区| 欧美一站二站| 99国内精品久久| 欧美激情第五页| 欧美一级午夜免费电影| 亚洲人www| 精品不卡视频| 国产一区二区三区av电影| 欧美精品福利| 免费观看30秒视频久久|