藍橋杯vip 基礎練習 Huffuman樹

2021-10-05 07:41:40 字數 1163 閱讀 6819

試題 基礎練習 huffuman樹

資源限制

時間限制:1.0s 記憶體限制:512.0mb

問題描述

huffman樹在編碼中有著廣泛的應用。在這裡,我們只關心huffman樹的構造過程。

給出一列數=,用這列數構造huffman樹的過程如下:

1. 找到中最小的兩個數,設為pa和pb,將pa和pb從中刪除掉,然後將它們的和加入到中。這個過程的費用記為pa + pb。

2. 重複步驟1,直到中只剩下乙個數。

在上面的操作過程中,把所有的費用相加,就得到了構造huffman樹的總費用。

本題任務:對於給定的乙個數列,現在請你求出用該數列構造huffman樹的總費用。

例如,對於數列=,huffman樹的構造過程如下:

1. 找到中最小的兩個數,分別是2和3,從中刪除它們並將和5加入,得到,費用為5。

2. 找到中最小的兩個數,分別是5和5,從中刪除它們並將和10加入,得到,費用為10。

3. 找到中最小的兩個數,分別是8和9,從中刪除它們並將和17加入,得到,費用為17。

4. 找到中最小的兩個數,分別是10和17,從中刪除它們並將和27加入,得到,費用為27。

5. 現在,數列中只剩下乙個數27,構造過程結束,總費用為5+10+17+27=59。

輸入格式

輸入的第一行包含乙個正整數n(n<=100)。

接下來是n個正整數,表示p0, p1, …, pn-1,每個數不超過1000。

輸出格式

輸出用這些數構造huffman樹的總費用。

樣例輸入

55 3 8 2 9

樣例輸出

59沒什麼複雜的地方,就是簡單模擬。

ac**:

#include

#include

#include

#include

using

namespace std;

intmain()

for(i=

1;i) cout

}

藍橋杯 VIP 基礎練習 報時助手

基礎練習 報時助手 時間限制 1.0s 記憶體限制 512.0mb 問題描述 給定當前的時間,請用英文的讀法將它讀出來。時間用時h和分m表示,在英文的讀法中,讀乙個時間的方法是 如果m為0,則將時讀出來,然後加上 o clock 如3 00讀作 three o clock 如果m不為0,則將時讀出來...

藍橋杯 基礎練習VIP 矩陣乘法

題目描述 給定乙個n階矩陣a,輸出a的m次冪 m是非負整數 例如 a 1 23 4 a的2次冪 7 10 15 22 輸入 第一行是乙個正整數n m 1 n 30,0 m 5 表示矩陣a的階數和要求的冪數 接下來n行,每行n個絕對值不超過10的非負整數,描述矩陣a的值 輸出 輸出共n行,每行n個整數...

藍橋杯 基礎練習VIP 報時助手

給定當前的時間,請用英文的讀法將它讀出來。時間用時h和分m表示,在英文的讀法中,讀乙個時間的方法是 如果m為0,則將時讀出來,然後加上 o clock 如3 00讀作 three o clock 如果m不為0,則將時讀出來,然後將分讀出來,如5 30讀作 five thirty 時和分的讀法使用的是...