## UVA 10226 - Hardwood Species ### 題意: ###### 給你很多棵樹,要求你按照字母排序輸出每種樹的出現頻率。 ### Sample Input: ###### 1. 第一行是test case的總數 ###### 2. 接下來用一個blank line隔開test case ###### 3. ==每個test case之間用一個blank line隔開== ###### 4. 一個test case裡面有不知道多少棵樹(種類名稱),直到遇到blank line ```= 1 Red Alder Ash Aspen Basswood Ash Beech Yellow Birch Ash Cherry Cottonwood Ash Cypress Red Elm Gum Hackberry White Oak Hickory Pecan Hard Maple White Oak Soft Maple Red Oak Red Oak White Oak Poplan Sassafras Sycamore Black Walnut Willow ``` ### Sample Output: ###### 1. 每個test case輸出每種樹的名稱 (alphabetical order, 照字母排序),以及該樹的percentage of population (樹口百分比?) ###### 2. 兩個test case之間用一個blank line分隔。(注意: ==最後一個test case後面不能有blank line==,會PE) ```= Ash 13.7931 Aspen 3.4483 Basswood 3.4483 Beech 3.4483 Black Walnut 3.4483 Cherry 3.4483 Cottonwood 3.4483 Cypress 3.4483 Gum 3.4483 Hackberry 3.4483 Hard Maple 3.4483 Hickory 3.4483 Pecan 3.4483 Poplan 3.4483 Red Alder 3.4483 Red Elm 3.4483 Red Oak 6.8966 Sassafras 3.4483 Soft Maple 3.4483 Sycamore 3.4483 White Oak 10.3448 Willow 3.4483 Yellow Birch 3.4483 ``` ### 程式碼: ```cpp= #include <iostream> #include <string> #include <map> #define haku author using namespace std; int main() { string str; int c; getline(cin, str); // 也可以用cin,只是要記得ignore/get掉下一個換行字元 c = stoi(str); getline(cin, str); // 這行只是要吃掉test case數量和第一個test case之間的blank line而已,沒啥意義 while (c--) { map<string, int> treePop; int cnt = 0; // 拿來算總共有幾棵樹的變數 while (getline(cin, str) && str != "") { if (treePop.find(str) != treePop.end()) treePop[str]++; // map裡面已經有這個種類的樹就+1 else treePop.insert({ str, 1 }); // map裡面沒有這種樹就insert cnt++; } for (auto& p : treePop) { cout << p.first << ' '; printf("%.4f\n", (float)p.second / (float)cnt * 100); // 也可以用<iomanip>裡面的setprecision(如下,記得include<iomanip>),但我懶,printf比較好寫 // cout << fixed << setprecision(4) << (float)p.second / (float)cnt * 100 << endl; } if (c > 0) cout << endl; } return 0; } // by. Haku ```