1. 程式人生 > >課程設計:十大歌手排行榜

課程設計:十大歌手排行榜

唉,課程設計,沒辦法,還是花了點時間寫咯。。紀念一下~

#include<bits/stdc++.h>
using namespace std;
int cnt;
set<string> s; //建立二叉排序樹
set<string>::iterator it;
map<string,int> m; //歌手與票數以hash表的形式儲存
map<string,string> mm; //歌手與主打歌曲通過hash映照
struct P
{
    string name, song;
    int num;
}p[10010];
bool cmp(P c, P d) {return c.num > d.num;}

void Sort() //按投票數排序
{
    cnt = 0;
    for(it=s.begin(); it!=s.end(); it++)
    {
        p[cnt].name = (*it);
        p[cnt].num = m[(*it)];
        p[cnt++].song = mm[(*it)];
    }
    sort(p,p+cnt,cmp);
}

void Solve_1() //給喜歡的歌手投票
{
    string name, song;
    printf("請輸入歌手名字:");
    cin >> name;
    if(mm[name] == "")
    {
        printf("請輸入歌手的主打歌曲:");
        cin >> song;
        mm[name] = song; //利用hash表每個歌手對應著其主打歌曲
    }
    s.insert(name);
    m[name]++; //此歌手票數加1
    cout << "歌手" << name << "已經有" <<  m[name] << "票啦!\n\n";
}

void Solve_2() //檢視上榜歌手主打歌曲
{
    if(s.size() < 10) puts("人數還不足十個,請稍後檢視");
    else
    {
        for(int i = 0; i<10; i++)
            cout << p[i].name << " 主打歌曲為 《" << mm[p[i].name] << "》\n\n";
    }
}

void Solve_3() //檢視歌手票數
{
    string name;
    printf("請輸入要檢視歌手的名字:");
    cin >> name;
    cout << name << "現在已有:" << m[name] << "票\n\n";
}

void Solve_4() //排行榜
{
    if(s.size() < 10) {puts("人數尚不足十個"); return ;}
    puts("\n");
    cout << "          " << "十大流行歌手" << endl;
    cout << "          " << "歌手名字[得票數]" << endl;
    for(int i=0; i<38; i++) printf("-");
    puts("");
    for(int i=0; i<10; i++)
        cout << "          " << p[i].name << "[" << p[i].num << "]\n";
    cout << endl;
}

void Solve() //列印初始化頁面
{
    cout << "***************************************" << endl;
    cout << "*             十大流行歌手            *" << endl;
    cout << "*-------------------------------------*" << endl;
    cout << "*        1.給喜歡的歌手投票           *" << endl;
    cout << "*        2.檢視上榜歌手主打歌曲       *" << endl;
    cout << "*        3.檢視歌手票數               *" << endl;
    cout << "*        4.排行榜                     *" << endl;
    cout << "*        0.儲存並退出                 *" << endl;
    cout << "***************************************" << endl;
    cout << '\n' << "Please select(1,2,3,4,0): " ;
}

int main()
{
    string t;
    char fname[100], fsong[100];
    int fnum;

    freopen("out.txt", "r", stdin); //從檔案輸入
    while(scanf("%s [%d] %s", fname,&fnum,fsong) != EOF)
    {
        string x = fname;
        s.insert(x), m[x] = fnum, mm[x] = fsong;
    }
    Sort();
    freopen("CON", "r", stdin); //改為從控制檯輸入
    while(1)
    {
        Solve();
        cin >> t;
        if(t == "1") {Solve_1(); Sort();}
        else if(t == "2") Solve_2();
        else if(t == "3") Solve_3();
        else if(t == "4") Solve_4();
        else if(t == "0") break;
        else puts("非法輸入!!!\n");
    }
    freopen("out.txt", "w", stdout); //從檔案輸出
    for(int i=0; i<cnt; i++)
        cout << p[i].name << " [" << p[i].num << "]" << p[i].song << endl;
    fclose(stdin); fclose(stdout);
    return 0;
}
學到了如何從檔案輸入與從控制檯輸入的相互轉化。

txt檔案:

張學友 [0] 一路上有你
劉歡 [0] 彎彎的月亮
周華健 [0] 朋友
劉德華 [0] 今天
梁靜茹 [0] 暖暖
周杰倫 [0] 龍捲風
劉惜君 [0] 我很快樂
王菲 [0] 紅豆
許嵩 [0] 斷橋殘雪
蘇打綠 [0] 再遇見