Leetcode 215 First K Largest Element

这种前几大的题通通用partition就可以在O(N)时间内解决,之所以要特意写个题解是因为想把partition的算法记下来,每次写都写得很纠结

程序看着比较奇怪,因为我是找的前k大,然后再找前k大里面最小的,之所以这样是为了复用之前
https://leetcode.com/problems/best-time-to-buy-and-sell-stock-iv/description/
的函数

type pair struct {
v int
p int
}

func maxProfit(k int, prices []int) int {
n := len(prices)
stack := make([]pair, n)
profits := make([]int, 0, n)
v := 0
p := -1
top := 0
for true {
for v = p + 1; v+1 < n && prices[v] >= prices[v+1]; v++ {
}
for p = v; p+1 < n && prices[p] <= prices[p+1]; p++ {
}
//fmt.Println(v,p)
if v == p {
break
}
/*case 1, do nothing but pop the last vp pair and put them into the profit array
/
for top > 0 && prices[v] <= prices[stack[top-1].v] {
profits = append(profits, prices[stack[top-1].p]-prices[stack[top-1].v])
top--
}
/
case 2, merge the two vp pairs
*/
for top > 0 && prices[p] >= prices[stack[top-1].p] {
profits = append(profits, prices[stack[top-1].p]-prices[v])
v = stack[top-1].v
top--
}
stack[top] = pair{v: v, p: p}
top++
}
for top > 0 {
profits = append(profits, prices[stack[top-1].p]-prices[stack[top-1].v])
top--
}
ans := 0
//fmt.Println(profits)
if len(profits) <= k {
ans = accumulate(profits)
return ans
}
ans = accumulate(firstKLargest(profits, k))
return ans

}

func accumulate(arr []int) int{
n := len(arr)
ans := 0
for i := 0; i < n; i++ {
ans += arr[i]
}
return ans
}

func firstKLargest(slice []int, k int) []int {
length := len(slice)

if length <= k {
    return slice
}

m := slice[rand.Intn(length)]

less := make([]int, 0, length)
more := make([]int, 0, length)
equal := make([]int, 0, length)

for _, item := range slice {
    switch {
    case item < m:
        less = append(less, item)
    case item > m:
        more = append(more, item)
    default :
        equal = append(equal, item)
    }
}
if len(more) > k {
    return firstKLargest(more, k)
} else if len(more) == k {
    return more
}else if len(more) + len(equal) >= k{
    more = append(more, equal[:k-len(more)]...)
    //fmt.Println("debug more",more)
    return more
}
more = append(more, equal...)
// fmt.Println("Less", less)
// fmt.Println("More", more)
// fmt.Println("Equal", equal)
part := firstKLargest(less, k-len(more))
return append(part, more...)

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,719评论 0 33
  • Lesson 11excuse[ik'skju:z] v.原谅2me[mi:,mi] pron.我(宾格)3yes...
    造物家英语阅读 1,211评论 0 0
  • 随着地球的自转,太阳照常从东方升起,今天早上的阳光仿佛一改往日的激烈,把温和而浪漫的阳光洒进了房间,昨天和...
    茶古马阅读 232评论 0 0
  • 我刚吃饭回来就看到他和他的不知所措。他站在前台,在陌生的环境里显得格格不入。 中等身材,剃着平头,浓眉,标准的国字...
    莎樂阅读 1,347评论 0 7
  • 我坐在一把藤木椅上,桌前放了一盆红色郁金香网丝花,一如当年制作时的鲜艳。我一时兴起铺开素描纸,想画起昨天梦...
    清天一梦阅读 357评论 0 3