試題 基礎練習 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 時和分的讀法使用的是...