课程设计:十大歌手排行榜

原创 2015年07月09日 13:13:34

唉,课程设计,没办法,还是花了点时间写咯。。纪念一下~

#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] 再遇见

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

课程设计<2>---歌手大奖赛计分程序

Copyright (c) 2016, 烟台大学计算机与控制学院 All ringts reserved. 文件名称:歌手大奖赛计分程序 作 者:王兴振 完成日期:2016年1月5日 版 本 号:未知...

大一下学期课程设计

一,文件相关操作 1,判断一个程序是否含有合法数量的main函数。 代码: #include #include /**************************************...

大二下小学期《数据结构》课程设计报告1

题目一: 基本查找算法比较 1) 对以下 3 种基本的查找算法的性能进行比较:顺序查找,二叉查找树,哈希。算法 包含两步:第一步:从文件中读取数据建查找表;第二步从文件中读取查找关键字 静态查找...

吉大 计算机编程能力培养课程设计 完美的代价

本人本着作业开源的思想,在完成作业后,将作业

Java课程设计 大整数类 实现加法

大数类: // Filename: BigInt.java class BigInt { BigInt(){} BigInt(int len) { bigint = new in...

统计c程序的一个设计,牛小芙老大的课程设计。觉得不错,收藏了。

/*【问题描述】 读入一个C程序,统计程序中代码、注释和空行的行数以及函数的个数和平均行数,并利用统计信息分析评价该程序的风格。 【基本要求】 (1) 把 C 程序文件按字符顺序读入源程序; ...

2013 十大root工具排行榜

  • 2014-01-20 15:18
  • 560KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)