在百度上学的,你们自己看看吧!歌曲top 10排行榜!!!

#include
#include
#include
 
struct Song_Ranking
{
    int ID;  //歌曲编号
    char Sname[20]; //歌曲名称 
    char singer[20];  //歌手名字
    long ticket;    //票数 
    struct Song_Ranking *next;
};
 
int option;        //选项
struct Song_Ranking *head,*tail,*move;    //head是头指针,tail是尾指针,move是代替head移动的指针 
int n=0;    //记录歌曲的数量 
void function();    //各项功能函数 
void choose();    //是否查看管理系统 
void menu();    //菜单
void information();        //所有歌曲信息 
void help();    //使用帮助 
void input();   //输入歌曲信息 
void write();    //歌曲信息写入文件 
void look();    //浏览歌曲信息
void vote();    //对歌曲进行投票 
void rank();    //top10排行榜 
void quit();    //退出 
int main()
{
    head=(struct Song_Ranking *)malloc(sizeof(struct Song_Ranking));
    if(!head)
    {
        printf("错误,结束!\n");
        exit(0);
    }
    head->next=NULL;
    menu();
    return 0;
}
void choose()
{
    printf("\n是否查看系统功能菜单:\n");
    printf("\n1、是,0、否\n");
    printf("\n输入:"); 
    int t;    //用来是否查看管理系统 
    scanf("%d",&t); 
    if(t==1) menu();
 } 
 void function()
{
    printf("请输入你要做的选项:");
    scanf("%d",&option);
    switch(option)
    {
        case 1:menu();break; 
        case 2:information();break; 
        case 3:help();break;
        case 4:input();break;
        case 5:look();break;
        case 6:vote();break;
        case 7:rank();break; 
        case 8:quit();
        default:printf("\n已退出系统!!!\n");
    }
 } 
 void menu()
{
    printf("\n\n");
    printf("*----------------------------------------------------\n");    
    printf("*               歌曲排行榜管理系统                  *\n");
    printf("*****************************************************\n");
    printf("********************系统功能菜单*********************\n");
    printf("----------------------     --------------------------\n");
    printf("*****************************************************\n");
    printf("**    1、菜单           *     2、所有参赛歌曲信息  **\n");
    printf("*****************************************************\n");
    printf("**    3、使用说明       *     4、输入歌曲信息      **\n");
    printf("*****************************************************\n");
    printf("**    5、浏览歌曲信息   *     6、对歌曲进行投票    **\n");
    printf("*****************************************************\n");
    printf("**    7、TOP10排行榜    *     8、退出              **\n"); 
    printf("*****************************************************\n");     
    printf("----------------------     --------------------------\n");
    printf("\n\n");
    system("pause");
    function();
 }
 void information()
{
    printf("所有歌曲信息如下:\n");
    printf("\n歌曲编号      歌曲名称        歌手          票数\n");
    printf("\n  101         《童年》       罗大佑           0  \n");
    printf("\n  102        《起风了》    买辣椒也用券       0  \n");
    printf("\n  103         《水手》       郑智化           0  \n");
    printf("\n  104       《纸短情长》     烟把儿           0  \n");
    printf("\n  105        《生僻字》      陈珂宇           0  \n"); 
    printf("\n  106       《海阔天空》     黄家驹           0  \n");
    printf("\n  107     《当爱已成往事》   李宗盛           0  \n");
    printf("\n  108      《贝加尔湖畔》     李健            0  \n");
    printf("\n  109      《父亲的散文诗》   许飞            0  \n");
    printf("\n  110         《成都》        赵雷            0  \n");
    printf("\n  111         《吻别》       张学友           0  \n");
    printf("\n  112     《失恋阵线联盟》    草蜢            0  \n");
    printf("\n"); 
    system("pause");
    choose();
    function();
 } 
 void help()
{
    printf("\n这是一个歌曲排行榜的菜单化信息管理程序,为了您能更快的去了解使用它,请您仔细阅读以下注意事项:\n");
    printf("\n\t\t注意事项:\n");
    printf("\n\t1、当您第一次使用该系统时,建议您先输出歌曲的信息并存储!\n");
    printf("\n\t2、如果想要使用TOP10这个功能,必须先进行歌曲投票后方可使用。\n");
    printf("\n\t3、在您使用完某一功能时,建议你保存到文件中!\n");
    printf("\n\t4、使用遇到任何问题请与我们联系\n");
    printf("\n\t5、最后感谢您的使用!\n"); 
    printf("\n");
    
    system("pause");
    choose();
    function();
}
void input()
{
    tail=head;        
    move=head;
    struct Song_Ranking *p;        //p是新创建的区域,存放输入的数据,然后与head连接起来 
    p=(struct Song_Ranking*)malloc(sizeof(struct Song_Ranking));
    if(!p)
    {
        printf("错误,结束!\n");
        exit(0);
    }    //判断是否成功开辟 
    printf("\n当所有的数据输入都为0时,结束输入!\n");
    printf("请输入歌曲的信息:\n");
    printf("歌曲编号:");
    scanf("%d",&p->ID);
    printf("歌曲名称:");
    scanf("%s",p->Sname);
    printf("歌手:");
    scanf("%s",p->singer);
    printf("票数(所有的人的票数在输入时都为零):");
    scanf("%ld",&p->ticket);
    while(p->ID!=0)        //输入的歌曲编号为零时结束输入 
    {
        n++;
        p->next=tail->next;
        tail->next=p;
        tail=p;
        p=(struct Song_Ranking*)malloc(sizeof(struct Song_Ranking));
        if(!p)
        {
            printf("错误,结束!\n");
            exit(0);
        }    
        printf("请输入歌曲的信息:\n");
        printf("歌曲编号:");
        scanf("%d",&p->ID);
        printf("歌曲名称:");
        scanf("%s",p->Sname);
        printf("歌手:");
        scanf("%s",p->singer);
        printf("票数(所有的人的票数在输入时都为零):");
        scanf("%ld",&p->ticket);
     } 
     int check;    //检查信息是否输入有误
     printf("\n请选择是否检查输入的歌曲信息(输入1是,0为否):"); 
     scanf("%d",&check);
     if(check)
     {
         while(move->next!=NULL)
         {
             printf("  %d   \t%s   \t%s   \t%ld\n",move->next->ID,move->next->Sname,move->next->singer,move->next->ticket);
            if(move->next->next==NULL) printf("\n歌曲信息输出完毕\n");
            move=move->next;
          } 
      } 
    write();
    system("pause");
    choose();
    function();
 } 
 void write()
 {
     FILE *fp;
     struct Song_Ranking *p; 
     p=head;
     if((fp=fopen("Song-Ranking.dat","w"))==NULL)
    {
        printf("\n无法打开此文件\n");
        exit(0);
     }
    while(p->next!=NULL)
    {
        p=p->next;
        fprintf(fp,"%d %s %s %ld\n",p->ID,p->Sname,p->singer,p->ticket);
    }
    fclose(fp);
  } 
  void look()
 {
     move=head;
     while(move->next==NULL)
    {
        printf("\n没有歌曲的信息,请添加后再来浏览!\n");break;
    }
     while(move->next!=NULL)
    {
        printf("%d\t %s\t %s\t %ld\n",move->next->ID,move->next->Sname,move->next->singer,move->next->ticket);
        if(move->next->next==NULL) printf("\n歌曲信息输出完毕\n");
        move=move->next;
    }
     printf("\n");
     system("pause");
     choose();
    function();
 }
 void vote()
 {
     move=head;
    while(move->next==NULL)
    {
        printf("\n无任何歌曲的信息,请在更新后重新使用此功能!\n");break;
     } 
    int ball; //ball是每次投票的歌曲编号 
    printf("\n当输入-1时结束投票\n"); 
     printf("请输入要投的歌曲的编号:");
     scanf("%d",&ball);        //当输入的编号为-1时,投票结束 
     while(ball!=-1)
     {
         while(move->next!=NULL)
         {
             if(ball==move->next->ID) 
             {
                 move->next->ticket=move->next->ticket+1;
                 break;
             }
             move=move->next;
         }
         move=head;        //进行完一次投票后,move回到head指针的位置,进行下一次投票,知道编号为-1结束 
         while(move->next==NULL)
         {
             printf("\n无任何歌曲的信息,无法进行投票。\n");break;
             } 
        printf("请输入要投的歌曲的编号:");
         scanf("%d",&ball);        //当输入的编号为-1时,投票结束
    }
    write();
    system("pause");
    choose();
    function();
 }
 void rank()
 {
     move=head;
     tail=head->next;
     while(move->next==NULL)
     {
         printf("\n无任何歌曲信息,请在更新歌曲信息后再做此处理。\n");break;
     }
     int i,j,k;
     int temp_ID;        //歌手编号交换中间变量 
     char temp_Sname[20];        //歌曲名称交换中间变量 
     char temp_singer[20];        //歌手姓名交换中间变量 
     long temp_ticket;        //票数交换中间变量 
     
     
     //用冒泡交换各个区域内的所有值 
       for(i=0;i          {
             for(j=1;j              {
                 if(move->next->ticket < move->next->next->ticket)
                 {
                     temp_ID=move->next->ID;
                    move->next->ID=move->next->next->ID;
                    move->next->next->ID=temp_ID;
                    
                    strcpy(temp_Sname,move->next->Sname);
                    strcpy(move->next->Sname,move->next->next->Sname);
                    strcpy(move->next->next->Sname,temp_Sname);
                    
                    strcpy(temp_singer,move->next->singer);
                    strcpy(move->next->singer,move->next->next->singer);
                    strcpy(move->next->next->singer,temp_singer);
                    
                    temp_ticket=move->next->ticket;
                    move->next->ticket=move->next->next->ticket;
                    move->next->next->ticket=temp_ticket;
                 }
                 move=move->next;
             }
             move=head;
         }
      move=head;
      printf("\nTOP10排行榜信息如下:\n");
      for(k=0;k<10;k++)
      {
           printf("%d %s %s %ld\n",move->next->ID,move->next->Sname,move->next->singer,move->next->ticket);
           move=move->next;
      } 
      printf("\nTOP10排行榜信息输入完毕!\n");
    write();
    system("pause");
    choose();
    function();
  } 
   void quit()
  {
      
   } 

你可能感兴趣的:(算法,c++,数据结构,开发语言)