動態(tài)規(guī)劃——完美平方

參考文章

http://www.cnblogs.com/pk28/p/5827338.html

題目

給一個正整數(shù) n, 找到若干個完全平方數(shù)(比如1, 4, 9, ... )使得他們的和等于 n。你需要讓平方數(shù)的個數(shù)最少。

只需要輸出最少的個數(shù)苗胀。

同時酪碘,還有一個定理:四方定理:所有自然數(shù)至多只要用四個數(shù)的平方和就可以表示禁偎。

該題可以使用動態(tài)規(guī)劃來解:
給定的整數(shù)從1開始增大到n叛买,然后使用一個一維數(shù)組來存儲給定數(shù)需要的平方數(shù)的個數(shù)母截。

后一個狀態(tài)與前一個狀態(tài)的轉換:

//n為給定爽柒,m為從1增長到n
//memo[]為備忘錄
for(int i = 0; i*i <m; i++)
{
  memo[i]=min(memo[i], memo[m - i*i] + 1)
}

外部一個循環(huán)m從1到n吴菠,內(nèi)部的狀態(tài)轉換公式為:
min內(nèi)部的始終取值最小的,memo[m - i*i] +1 意思為:
+1表示的是 i*i這個平方數(shù)所占的一項浩村。
剩下的個數(shù)為做葵,之前求出的meme[m - i*i]。

從1到最大的平方數(shù)心墅,挨個減嘗試酿矢,存儲最小值。

變形

這個問題可以轉換為判斷一個數(shù)是幾個平方數(shù)的和怎燥。

bool isOne(int n)
{
  int a= sqrt(n);
  return n == a*a;
}

bool isTwo(int n)
{
for(int i = 0; i*i < n;i++)
{
  if(isOne(n - i*i))
  {return true ;}
}
return false;
}

bool isThree(int n)
{
 for(int i = 0; i*i < n ;i++)
  {
    if(isTwo(n  - i*i ))
    {return true;}
  }
  return false;
}

在使用的時候以此從1到3開始調用函數(shù)判斷瘫筐。

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市铐姚,隨后出現(xiàn)的幾起案子策肝,更是在濱河造成了極大的恐慌,老刑警劉巖谦屑,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驳糯,死亡現(xiàn)場離奇詭異,居然都是意外死亡氢橙,警方通過查閱死者的電腦和手機酝枢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來悍手,“玉大人帘睦,你說我怎么就攤上這事√箍担” “怎么了竣付?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長滞欠。 經(jīng)常有香客問我古胆,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任逸绎,我火速辦了婚禮惹恃,結果婚禮上,老公的妹妹穿的比我還像新娘棺牧。我一直安慰自己巫糙,他們只是感情好,可當我...
    茶點故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布颊乘。 她就那樣靜靜地躺著参淹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪乏悄。 梳的紋絲不亂的頭發(fā)上浙值,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天,我揣著相機與錄音纲爸,去河邊找鬼亥鸠。 笑死,一個胖子當著我的面吹牛识啦,可吹牛的內(nèi)容都是我干的负蚊。 我是一名探鬼主播,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼颓哮,長吁一口氣:“原來是場噩夢啊……” “哼家妆!你這毒婦竟也來了?” 一聲冷哼從身側響起冕茅,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤伤极,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后姨伤,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體哨坪,經(jīng)...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年乍楚,在試婚紗的時候發(fā)現(xiàn)自己被綠了当编。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,505評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡徒溪,死狀恐怖忿偷,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情臊泌,我是刑警寧澤鲤桥,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站渠概,受9級特大地震影響茶凳,放射性物質發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一慧妄、第九天 我趴在偏房一處隱蔽的房頂上張望顷牌。 院中可真熱鬧,春花似錦塞淹、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至状共,卻和暖如春套耕,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背峡继。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工冯袍, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人碾牌。 一個月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓康愤,卻偏偏與公主長得像,于是被迫代替她去往敵國和親舶吗。 傳聞我的和親對象是個殘疾皇子征冷,可洞房花燭夜當晚...
    茶點故事閱讀 45,515評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 計算機二級C語言上機題庫(南開版) 1.m個人的成績存放在score數(shù)組中,請編寫函數(shù)fun,它的功能是:將低于平...
    MrSunbeam閱讀 6,391評論 1 42
  • 背景 一年多以前我在知乎上答了有關LeetCode的問題, 分享了一些自己做題目的經(jīng)驗誓琼。 張土汪:刷leetcod...
    土汪閱讀 12,748評論 0 33
  • 夜检激,靜靜的來, 它告訴每一個沐浴黑暗的姑娘腹侣, 該睡了…… 當她躺下叔收, 還未閉上雙眼, 黑夜里的凝視讓她突兀地思緒萬...
    周小錦閱讀 236評論 4 5
  • 《孩子學習不用愁》傲隶,作者為金色雨林學習能力研究中心創(chuàng)始人林薇饺律。 全書十四章,圍繞一個問題——如何培養(yǎng)孩子學習能力伦籍?...
    湯垚閱讀 277評論 0 1