nyoj55 懶省事的小明

2021-07-26 17:11:09 字數 994 閱讀 3216

原題鏈結

這道題之前做過,今天重做了一次,各種wrong answer,心情十分沮喪。標準程式也過不去,後來看了討論區才知道測試資料的值偏大(最大結果可以到24億),所以要用long long型別。

原理:跟huffman樹有點相似,使權重(即果實個數)大的離根節點更近,通俗說就是在合併過程中,個數多的堆放到後面再合併。

方法一 用stl中priority_queue優先佇列,但是預設為從大到小排序,通過改寫比較結構體,模擬最小堆,使佇列的首元素權重最小。

方法二 用stl中的multiset,集合中預設排序從小到大,更方便,果然還是不夠熟悉。

**如下:

//方法一 :用priority_queue

#include

#include

using namespace std;

struct cmp //因為priority_queue預設是從大到小排序,所以自己定義cmp結構體,使資料從小到大排序

};int main()

printf("%lld\n",result);

} return 0;}

//方法二 :multiset(改編自nyoj標準程式)

#include

#include

using namespace std;

int main()

while(1)

multiset::iterator it=v.begin();

long long a=*it;

long long b=*(++it);

v.erase(v.begin());

v.erase(v.begin());

v.insert(a+b);

sum=sum+a+b;

}printf("%lld\n",sum);

} return 0;}

//小貼士:一開始我以為輸入格式採用 %i64d或者%lld應該都可以ac,可是用%i64d輸入會超時,應該是oj要求吧。

NYOJ 55懶省事的小明

時間限制 3000 ms 記憶體限制 65535 kb 難度 3 描述 小明很想吃果子,正好果園果子熟了。在果園裡,小明已經將所有的果子打了下來,而且按果子的不同種類分成了不同的堆。小明決定把所有的果子合成一堆。因為小明比較懶,為了省力氣,小明開始想點子了 每一次合併,小明可以把兩堆果子合併到一起,...

NYOJ 55 懶省事的小明

時間限制 3000 ms 記憶體限制 65535 kb 難度 3 描述 小明很想吃果子,正好果園果子熟了。在果園裡,小明已經將所有的果子打了下來,而且按果子的不同種類分成了不同的堆。小明決定把所有的果子合成一堆。因為小明比較懶,為了省力氣,小明開始想點子了 每一次合併,小明可以把兩堆果子合併到一起,...

nyoj55懶省事的小明

這個題沒啥特別的,思想特別簡單,就是我們學資料結構的時候,那裡面的哈夫曼樹的思想,從一組數裡面選兩個最小的相加,將這兩個數從這組數中刪除,再將這兩個數的和放進去,再從這組數中選兩個最小的數以此類推,優先佇列 堆 的主要作用就是兩個操作 插入,刪除最小,優先佇列插入和刪除元素的複雜度都是o log2n...