丑數(shù)(java)

題目描述:

把只包含因子2佑颇、3和5的數(shù)稱作丑數(shù)(Ugly Number)。例如6狡耻、8都是丑數(shù)墩剖,但14不是,因?yàn)樗蜃?夷狰。 習(xí)慣上我們把1當(dāng)做是第一個(gè)丑數(shù)岭皂。求按從小到大的順序的第N個(gè)丑數(shù)。

分析:

最開(kāi)始寫了個(gè)從1開(kāi)始判斷自然數(shù)是否是丑數(shù)沼头,直到找到第n個(gè)丑數(shù)為止爷绘。這個(gè)方法顯然耗時(shí)很久。(判斷一個(gè)數(shù)是否是丑數(shù)的思路:如果一個(gè)數(shù)能被2整除进倍,我們把它連續(xù)除以2土至;如果能被3整除,就連續(xù)除以3猾昆;如果能被5整除陶因,就除以5.如果最后我們得到的是1,那么這個(gè)數(shù)就是丑數(shù)垂蜗,否則不是楷扬。)

思路
只包含因子2,3解幽,5的數(shù)稱為丑數(shù),也就是說(shuō)一個(gè)丑數(shù)肯定是某個(gè)丑數(shù)乘以2,3,5的結(jié)果毅否。用一個(gè)數(shù)組保存已有的丑數(shù),然后計(jì)算后面的丑數(shù)蝇刀。(犧牲空間螟加,以換取時(shí)間)
這種方法的關(guān)鍵在于排序,每個(gè)丑數(shù)都是由別的丑數(shù)乘2/3/5來(lái)的吞琐,所以把所有的丑數(shù)存儲(chǔ)捆探,記住前面的下標(biāo),一旦前面那個(gè)數(shù)的乘2/3/5的丑數(shù)已經(jīng)被后邊使用站粟,就把相應(yīng)的下標(biāo)向前移動(dòng)一個(gè)黍图。

解答:

public class Solution {
    public int GetUglyNumber_Solution(int index) {
        if(index<=6) return index;
        int i2 =0,i3=0,i5=0;
        int[] dp = new int[index];
        dp[0]=1;
        for(int i=1;i<index;i++) {
            dp[i] = Math.min(dp[i2]*2,Math.min(dp[i3]*3,dp[i5]*5));//其中最小的為下一個(gè)丑數(shù)
            //把已經(jīng)存在的數(shù),往前移動(dòng)一下
            if(dp[i]==dp[i2]*2) i2++;
            if(dp[i]==dp[i3]*3) i3++;
            if(dp[i]==dp[i5]*5) i5++;
        }
        return dp[index - 1];
    }
}
運(yùn)行結(jié)果

始終相信奴烙,在線編程題目考的就是你的邏輯思維助被,不可能要你寫上一大堆的代碼,所以代碼一定是越簡(jiǎn)潔越好切诀。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末揩环,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子幅虑,更是在濱河造成了極大的恐慌丰滑,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,185評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件倒庵,死亡現(xiàn)場(chǎng)離奇詭異褒墨,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)擎宝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門郁妈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人绍申,你說(shuō)我怎么就攤上這事圃庭。” “怎么了失晴?”我有些...
    開(kāi)封第一講書人閱讀 163,524評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵剧腻,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我涂屁,道長(zhǎng)书在,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,339評(píng)論 1 293
  • 正文 為了忘掉前任拆又,我火速辦了婚禮儒旬,結(jié)果婚禮上栏账,老公的妹妹穿的比我還像新娘。我一直安慰自己栈源,他們只是感情好挡爵,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,387評(píng)論 6 391
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著甚垦,像睡著了一般茶鹃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上艰亮,一...
    開(kāi)封第一講書人閱讀 51,287評(píng)論 1 301
  • 那天闭翩,我揣著相機(jī)與錄音,去河邊找鬼迄埃。 笑死疗韵,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的侄非。 我是一名探鬼主播蕉汪,決...
    沈念sama閱讀 40,130評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼逞怨!你這毒婦竟也來(lái)了肤无?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 38,985評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤骇钦,失蹤者是張志新(化名)和其女友劉穎宛渐,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體眯搭,經(jīng)...
    沈念sama閱讀 45,420評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡窥翩,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,617評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鳞仙。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片寇蚊。...
    茶點(diǎn)故事閱讀 39,779評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖棍好,靈堂內(nèi)的尸體忽然破棺而出仗岸,到底是詐尸還是另有隱情,我是刑警寧澤借笙,帶...
    沈念sama閱讀 35,477評(píng)論 5 345
  • 正文 年R本政府宣布扒怖,位于F島的核電站,受9級(jí)特大地震影響业稼,放射性物質(zhì)發(fā)生泄漏盗痒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,088評(píng)論 3 328
  • 文/蒙蒙 一低散、第九天 我趴在偏房一處隱蔽的房頂上張望俯邓。 院中可真熱鬧骡楼,春花似錦、人聲如沸稽鞭。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,716評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)朦蕴。三九已至篮条,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間梦重,已是汗流浹背兑燥。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,857評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工亮瓷, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留琴拧,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,876評(píng)論 2 370
  • 正文 我出身青樓嘱支,卻偏偏與公主長(zhǎng)得像蚓胸,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子除师,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,700評(píng)論 2 354

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