日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

剑指offer:把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。

發(fā)布時(shí)間:2025/3/21 编程问答 23 豆豆

問題:把只包含質(zhì)因子2、3和5的數(shù)稱作丑數(shù)(Ugly Number)。例如6、8都是丑數(shù),但14不是,因?yàn)樗|(zhì)因子7。 習(xí)慣上我們把1當(dāng)做是第一個(gè)丑數(shù)。求按從小到大的順序的第N個(gè)丑數(shù)。


通俗易懂的解釋:

首先從丑數(shù)的定義我們知道,一個(gè)丑數(shù)的因子只有2,3,5,那么丑數(shù)p = 2 ^ x * 3 ^ y * 5 ^ z,換句話說一個(gè)丑數(shù)一定由另一個(gè)丑數(shù)乘以2或者乘以3或者乘以5得到,那么我們從1開始乘以2,3,5,就得到2,3,5三個(gè)丑數(shù),在從這三個(gè)丑數(shù)出發(fā)乘以2,3,5就得到4,6,10,6,9,15,10,15,25九個(gè)丑數(shù),我們發(fā)現(xiàn)這種方法會(huì)得到重復(fù)的丑數(shù),而且我們題目要求第N個(gè)丑數(shù),這樣的方法得到的丑數(shù)也是無序的。那么我們可以維護(hù)三個(gè)隊(duì)列

(1)丑數(shù)數(shù)組: 1

乘以2的隊(duì)列:2

乘以3的隊(duì)列:3

乘以5的隊(duì)列:5

選擇三個(gè)隊(duì)列頭最小的數(shù)2加入丑數(shù)數(shù)組,同時(shí)將該最小的數(shù)乘以2,3,5放入三個(gè)隊(duì)列

(2)丑數(shù)數(shù)組:1,2

乘以2的隊(duì)列:4

乘以3的隊(duì)列:3,6

乘以5的隊(duì)列:5,10

選擇三個(gè)隊(duì)列頭最小的數(shù)3加入丑數(shù)數(shù)組,同時(shí)將該最小的數(shù)乘以2,3,5放入三個(gè)隊(duì)列

(3)丑數(shù)數(shù)組:1,2,3

乘以2的隊(duì)列:4,6

乘以3的隊(duì)列:6,9

乘以5的隊(duì)列:5,10,15

選擇三個(gè)隊(duì)列頭里最小的數(shù)4加入丑數(shù)數(shù)組,同時(shí)將該最小的數(shù)乘以2,3,5放入三個(gè)隊(duì)列

(4)丑數(shù)數(shù)組:1,2,3,4

乘以2的隊(duì)列:6,8

乘以3的隊(duì)列:6,9,12

乘以5的隊(duì)列:5,10,15,20

選擇三個(gè)隊(duì)列頭里最小的數(shù)5加入丑數(shù)數(shù)組,同時(shí)將該最小的數(shù)乘以2,3,5放入三個(gè)隊(duì)列

(5)丑數(shù)數(shù)組:1,2,3,4,5

乘以2的隊(duì)列:6,8,10,

乘以3的隊(duì)列:6,9,12,15

乘以5的隊(duì)列:10,15,20,25

選擇三個(gè)隊(duì)列頭里最小的數(shù)6加入丑數(shù)數(shù)組,但我們發(fā)現(xiàn),有兩個(gè)隊(duì)列頭都為6,所以我們彈出兩個(gè)隊(duì)列頭,同時(shí)將12,18,30放入三個(gè)隊(duì)列;

……………………

疑問:

1.為什么分三個(gè)隊(duì)列?

丑數(shù)數(shù)組里的數(shù)一定是有序的,因?yàn)槲覀兪菑某髷?shù)數(shù)組里的數(shù)乘以2,3,5選出的最小數(shù),一定比以前未乘以2,3,5大,同時(shí)對(duì)于三個(gè)隊(duì)列內(nèi)部,按先后順序乘以2,3,5分別放入,所以同一個(gè)隊(duì)列內(nèi)部也是有序的;

2.為什么比較三個(gè)隊(duì)列頭部最小的數(shù)放入丑數(shù)數(shù)組?

因?yàn)槿齻€(gè)隊(duì)列是有序的,所以取出三個(gè)頭中最小的,等同于找到了三個(gè)隊(duì)列所有數(shù)中最小的。

實(shí)現(xiàn)思路:

我們沒有必要維護(hù)三個(gè)隊(duì)列,只需要記錄三個(gè)指針顯示到達(dá)哪一步;“|”表示指針,arr表示丑數(shù)數(shù)組;

(1)1

|2

|3

|5

目前指針指向0,0,0,隊(duì)列頭arr[0] * 2 = 2,? arr[0] * 3 = 3,? arr[0] * 5 = 5

(2)1 2

2 |4

|3 6

|5 10

目前指針指向1,0,0,隊(duì)列頭arr[1] * 2 = 4,? arr[0] * 3 = 3, arr[0] * 5 = 5

(3)1 2 3

2| 4 6

3 |6 9

|5 10 15

目前指針指向1,1,0,隊(duì)列頭arr[1] * 2 = 4,? arr[1] * 3 = 6, arr[0] * 5 = 5

………………


代碼:

class Solution { public:int GetUglyNumber_Solution(int index) {// 0-6的丑數(shù)分別為0-6if(index < 7) return index;//p2,p3,p5分別為三個(gè)隊(duì)列的指針,newNum為從隊(duì)列頭選出來的最小數(shù)int p2 = 0, p3 = 0, p5 = 0, newNum = 1;vector<int> arr;arr.push_back(newNum);while(arr.size() < index) {//選出三個(gè)隊(duì)列頭最小的數(shù)newNum = min(arr[p2] * 2, min(arr[p3] * 3, arr[p5] * 5));//這三個(gè)if有可能進(jìn)入一個(gè)或者多個(gè),進(jìn)入多個(gè)是三個(gè)隊(duì)列頭最小的數(shù)有多個(gè)的情況if(arr[p2] * 2 == newNum) p2++;if(arr[p3] * 3 == newNum) p3++;if(arr[p5] * 5 == newNum) p5++;arr.push_back(newNum);}return newNum;} };

?

總結(jié)

以上是生活随笔為你收集整理的剑指offer:把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 91精品久久久久久粉嫩 | 深夜视频一区二区 | 欧日韩在线视频 | 午夜电影一区二区三区 | 日韩字幕在线观看 | 蜜桃香蕉视频 | 国产猛男猛女超爽免费视频 | 99热精品国产 | 欧洲精品一区 | 久久免费高清 | 成人国产欧美 | 人人爽av| 69人妻一区二区三区 | 中文字幕精品视频在线观看 | 久久精品国产亚洲av香蕉 | aaa在线 | 乱日视频 | 国产叼嘿视频在线观看 | 亚洲人在线视频 | 91老师国产黑色丝袜在线 | 欧美v亚洲 | 影音先锋啪啪资源 | 在线观看免费视频 | 久九九 | 草草草在线 | 激情五月婷婷丁香 | 四虎永久在线精品 | 亚洲专区一区二区三区 | 国产在线精品成人欧美 | 国产免费一区二区三区在线观看 | 成人午夜黄色 | 日韩一区二区三区中文字幕 | 欧美大片www| 成为性瘾网黄的yy对象后 | 亚洲成av人片一区二区梦乃 | 91春色 | 老女人人体欣赏a√s | 日本大片黄 | 国产视频综合在线 | 亚洲国产欧美日韩在线 | 粉嫩av| 欧美午夜激情影院 | 亚洲天堂av网 | 国产真人无遮挡作爱免费视频 | 内地级a艳片高清免费播放 91在线精品一区二区 | 国产成人手机在线 | 亚洲自拍电影 | 久久久av一区二区三区 | 国产一级片播放 | 性欧美最猛 | 久久久久亚洲精品国产 | 成人免费视频观看视频 | 久久精品国产网红主播 | xxx性日本| 黄色一集片 | 亚洲特级片| 极品美女开粉嫩精品 | 亚洲成年人影院 | 国产一区二区三区四区hd | 青草视频在线观看视频 | 麻豆网站在线播放 | 国产人妻aⅴ色偷 | 捆绑无遮挡打光屁股 | 国产精品欧美激情在线 | 亚洲在线激情 | 无码人妻aⅴ一区二区三区 国产高清一区二区三区四区 | 亚洲欧美乱综合图片区小说区 | 国产毛片一区二区三区va在线 | 久久这里只有精品久久 | 日韩永久免费 | 日本成人在线免费视频 | 日本午夜激情视频 | 国产夫妻在线视频 | 久久综合国产 | 精品视频久久久久久久 | 免费的黄色网址 | 国内外成人激情视频 | 日韩精品免费一区 | 亚洲女同志亚洲女同女播放 | 久久久久久久久久久91 | www.伊人久久 | 天天狠天天操 | 日本中文字幕不卡 | 金瓶风月在线 | 国产美女明星三级做爰 | 超碰人人澡 | av免费大全 | 老太婆av| 亚洲天堂网站 | 东北高大丰满bbbbzbbb | 色多多视频在线 | 亚洲素人 | 五十路黄色片 | 秋霞福利视频 | www.精品一区 | 国产精品视频在线免费观看 | 成人做爰66片免费看网站 | 亚洲福利国产 | 国产真人毛片 |