這個(gè)題我第一次的想法就是把數(shù)據(jù)從小到大,然后依次合并,最后就能得到結(jié)果!
后來(lái)發(fā)現(xiàn),雖然最小的兩個(gè)合并,但是可能兩個(gè)小的合并后的數(shù)據(jù)大于下一個(gè),再次合并就是有問(wèn)題的。因此要對(duì)得到后的數(shù)據(jù)進(jìn)行排序再依次合并。
此時(shí),如果用普通的數(shù)組和sort函數(shù)的話(huà)必定會(huì)超時(shí),因此我們這里可以用到優(yōu)先隊(duì)列,下面附上一些用法。
#include//頭文件
priority_queue//定義
priority_queue,greater>q;//升序隊(duì)列
priority_queue,less>q;//降序隊(duì)列
priority_queuea//此時(shí)默認(rèn)為降序隊(duì)列
//greater和less是std實(shí)現(xiàn)的兩個(gè)仿函數(shù)(就是使一個(gè)類(lèi)的使用看上去像一個(gè)函數(shù)。其實(shí)現(xiàn)就是類(lèi)中實(shí)現(xiàn)一個(gè)operator(),這個(gè)類(lèi)就有了類(lèi)似函數(shù)的行為,就是一個(gè)仿函數(shù)類(lèi)了)
之后本題就很好解決了,下面附上代碼
#include#include
#includeusing namespace std;
const int N = 10005;
priority_queue, greater>a;
int main()
{
int n;
int c, x, y;
long long k = 0;
cin >>n;
for (int i = 1; i<= n; i++)
{
cin >>c;
a.push(c);
}
for (int i = 1; i<= n-1 ; i++)
{
x = a.top();
a.pop();
y = a.top();
a.pop();
a.push(x + y);
k += x + y;
}
cout<< k;
return 0;
}
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級(jí)服務(wù)器適合批量采購(gòu),新人活動(dòng)首月15元起,快前往官網(wǎng)查看詳情吧
網(wǎng)頁(yè)標(biāo)題:洛谷P1090題解-創(chuàng)新互聯(lián)
本文網(wǎng)址:http://www.rwnh.cn/article4/ceisoe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、響應(yīng)式網(wǎng)站、手機(jī)網(wǎng)站建設(shè)、做網(wǎng)站、網(wǎng)站設(shè)計(jì)、網(wǎng)站維護(hù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容