歌厅歌曲管理系统

系统功能:该系统以菜单方式工作,歌曲信息包括:歌名、演唱者、作词、作曲、所属专辑、出版时间、出版公司。试设计一歌厅歌曲管理系统,使之能提供以下功能:歌曲信息录入、修改、插入、删除功能;歌曲排序浏览功能;按歌名查询、按演唱者查询等功能。

完整的实现代码如下:

[cpp:firstline[0]] view plain copy print ?
  1. #include "stdio.h"   
  2. #include "stdlib.h"   
  3. #include "string.h"   
  4. //歌曲信息包括:歌名、演唱者、作词、作曲、所属专辑、出版时间、出版公司   
  5. typedef struct music  
  6. {  
  7.     char name[20];    //歌名   
  8.     char singer[20];  //演唱者   
  9.     char authors[20]; //作词   
  10.     char compose[30]; //作曲   
  11.     char album[20];   //所属专辑   
  12.     char time[15];    //出版时间   
  13.     char company[30]; //出版公司   
  14.     struct music *next;  
  15. }music;  
  16. music *head=NULL;  
  17. int length;   //链表的长度   
  18. void create()  
  19. {  
  20.     music *p1,*p2;  
  21.     length=0;  
  22.     p1=(music *)malloc(sizeof(music));  
  23.     strcpy(p1->name,"-1");  
  24.     if(head==NULL)  
  25.         head=p1;  
  26.     printf("请输入音乐的歌名、演唱者、作词、作曲、所属专辑、出版时间、出版公司:/n");  
  27.     while(1)  //歌名为0的时候退出   
  28.     {  
  29.         p2=(music *)malloc(sizeof(music));  
  30.         //输入歌曲信息   
  31.         scanf("%s %s %s %s %s %s %s",p2->name,p2->singer,p2->authors,p2->compose,p2->album,p2->time,p2->company);  
  32.         if(strcmp(p2->name,"0")==0)  
  33.         {  
  34.             printf("链表创建完成!/n");  
  35.             break;  
  36.         }  
  37.         length++; //链表的长度   
  38.         p1->next=p2;  
  39.         p2->next=NULL;  
  40.         p1=p1->next;  
  41.     }  
  42.     return ;  
  43. }  
  44. void ModifymusicInfo()  
  45. {  
  46.     music *p=head->next;  
  47.     char name[20];  
  48.     printf("请输入要修改的歌曲的歌名:");  
  49.     getchar();  
  50.     scanf("%s",name);  
  51.     while(p!=NULL)  
  52.     {  
  53.         if(strcmp(p->name,name)==0)  
  54.         {  
  55.             printf("修改前,歌名为%s的歌曲的信息如下:/n",name);  
  56.             printf("音乐的歌名、演唱者、作词、作曲、所属专辑、出版时间、出版公司:/n");  
  57.             printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company);  
  58.             printf("请输入歌曲的新的所属专辑:");  
  59.             getchar();  
  60.             scanf("%s",p->album);  
  61.             printf("请输入歌曲的新出版公司:");  
  62.             getchar();  
  63.             scanf("%s",p->company);  
  64.             printf("修改后,歌名为%s的歌曲的信息如下:/n",name);  
  65.             printf("音乐的歌名、演唱者、作词、作曲、所属专辑、出版时间、出版公司:/n");  
  66.             printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company);  
  67.             return ;  
  68.         }  
  69.         p=p->next;  
  70.     }  
  71.     if(p==NULL)  
  72.     {  
  73.         printf("该歌曲不存在!/n");  
  74.         return ;  
  75.     }  
  76. }  
  77.   
  78. void display()  
  79. {  
  80.     music *p=head->next;  
  81.     printf("链表中所有的歌曲信息如下:/n");  
  82.     printf("音乐的歌名、演唱者、作词、作曲、所属专辑、出版时间、出版公司:/n");  
  83.     while(p!=NULL)  
  84.     {  
  85.         printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company);  
  86.         p=p->next;  
  87.     }  
  88.     return ;  
  89. }  
  90. void search()  
  91. {  
  92.     int num,x,flag;  
  93.     char name[20];  
  94.     music *p=head->next;  
  95.     printf("请选择查询的方式:/n");  
  96.     printf("1、按歌名查询/t 2、按演唱者查询/n");  
  97.     scanf("%d",&x);  
  98.     if(x==1)  
  99.     {  
  100.         printf("需要查找的歌曲歌名为:");  
  101.         getchar();  
  102.         scanf("%s",name);  
  103.         while(p!=NULL)  
  104.         {  
  105.   
  106.             if(strcmp(p->name,name)==0)  
  107.             {  
  108.                 printf("歌名为%s的歌曲的信息如下:/n",name);  
  109.                 printf("音乐的歌名、演唱者、作词、作曲、所属专辑、出版时间、出版公司:/n");  
  110.                 printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company);  
  111.                 return ;  
  112.             }     
  113.             p=p->next;  
  114.         }  
  115.         if(p==NULL)  
  116.             printf("没有这首歌曲的记录!/n");  
  117.     }  
  118.     else if(x==2)  
  119.     {  
  120.         flag=0;  
  121.         printf("需要查找的演唱者为:");  
  122.         getchar();  
  123.         scanf("%s",name);  
  124.         p=head->next;  
  125.         while(p!=NULL)  
  126.         {  
  127.             if(strcmp(p->singer,name)==0)  
  128.             {  
  129.                 if(flag==0)  
  130.                 {  
  131.                     printf("演唱者为%s的歌曲的信息如下:/n",name);  
  132.                     printf("音乐的歌名、演唱者、作词、作曲、所属专辑、出版时间、出版公司:/n");  
  133.                     flag=1;  
  134.                 }  
  135.                 printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company);  
  136.             }     
  137.             p=p->next;  
  138.         }  
  139.         if(p==NULL && flag==0)  
  140.         {  
  141.             printf("没有该演唱者的歌曲记录!/n");  
  142.             return;  
  143.         }  
  144.     }  
  145.     return ;  
  146. }  
  147.   
  148. void insert()  
  149. {  
  150.     int num,i;  
  151.     music *p,*q;  
  152.     p=head;  
  153.   
  154.     printf("请输入你要插入位置: ");  
  155.     scanf("%d",&num);  
  156.     if(num>length)  
  157.     {  
  158.         printf("找不到要插入的位置/n");  
  159.         return ;  
  160.     }  
  161.     else  
  162.     {  
  163.         printf("请输入你要插入的音乐的歌名、演唱者、作词、作曲、所属专辑、出版时间、出版公司:/n");  
  164.         q=(music *)malloc(sizeof(music));  
  165.         //输入歌曲信息   
  166.         scanf("%s %s %s %s %s %s %s",q->name,q->singer,q->authors,q->compose,q->album,q->time,q->company);  
  167.         while(p!=NULL)  
  168.         {  
  169.             if(strcmp(p->name,q->name)==0)  
  170.             {  
  171.                 printf("该歌曲已经存在,无法插入!/n");  
  172.                 return ;  
  173.             }  
  174.             p=p->next;  
  175.         }  
  176.         p=head;  
  177.         for(i=0;i<num;i++)  
  178.             p=p->next;  
  179.         q->next=p->next;  
  180.         p->next=q;  
  181.         length++;  
  182.         printf("插入成功!/n");  
  183.         return ;  
  184.     }  
  185. }    
  186.   
  187. void Delete()  
  188. {  
  189.     char name[20];  
  190.     music *p,*q;  
  191.     q=head,p=head->next;  
  192.     printf("请输入要删除的歌曲的歌名:/n");  
  193.     getchar();  
  194.     scanf("%s",name);  
  195.   
  196.     while(p!=NULL)  
  197.     {  
  198.         if(strcmp(p->name,name)==0)  
  199.         {  
  200.             q->next=p->next;  
  201.             free(p);  
  202.             length--;  
  203.             printf("删除成功!/n");  
  204.             return ;  
  205.         }  
  206.         p=p->next;  
  207.         q=q->next;  
  208.     }  
  209.     if(p==NULL)  
  210.     {  
  211.         printf("找不到要删除的歌曲!/n");  
  212.         return ;  
  213.     }  
  214. }  
  215. void menu()  
  216. {  
  217.     printf("________________________________________________________________/n");  
  218.     printf("|              歌厅歌曲管理系统                                |/n");  
  219.     printf("|               0、 退出系统                                   |/n");  
  220.     printf("|               1、 录入歌曲信息                               |/n");  
  221.     printf("|               2、 显示歌曲信息                               |/n");  
  222.     printf("|               3、 查找链表中的某一首歌曲                     |/n");  
  223.     printf("|               4、 删除链表中指定歌曲                         |/n");  
  224.     printf("|               5、 指定的位置上插入一个新结点                 |/n");  
  225.     printf("|               6、 修改歌曲信息                               |/n");  
  226.     printf("________________________________________________________________/n");  
  227.     return ;  
  228. }  
  229. int main(void)  
  230. {  
  231.     int a;  
  232.     menu();  
  233.     while(1)  
  234.     {  
  235.         printf("请选择相应的功能:");  
  236.         scanf("%d",&a);  
  237.         switch(a)  
  238.         {  
  239.         case 0:  
  240.             return 0;  
  241.         case 1:  
  242.             create();  
  243.             menu();  
  244.             break;  
  245.         case 2:  
  246.             if(head)  
  247.             {  
  248.                 display();  
  249.                 menu();  
  250.             }  
  251.             else  
  252.             {  
  253.                 printf("链表为空,请先建立链表!/n");  
  254.                 menu();  
  255.             }  
  256.             break;  
  257.         case 3:  
  258.             if(head)  
  259.             {  
  260.                 search();  
  261.                 menu();  
  262.             }  
  263.             else  
  264.             {  
  265.                 printf("链表为空,请先建立链表!/n");  
  266.                 menu();  
  267.             }  
  268.             break;  
  269.         case 4:  
  270.             if(head)  
  271.             {  
  272.                 Delete();  
  273.                 menu();  
  274.             }  
  275.             else  
  276.             {  
  277.                 printf("链表为空,请先建立链表!/n");  
  278.                 menu();  
  279.             }  
  280.             break;  
  281.         case 5:  
  282.             if(head)  
  283.             {  
  284.                 insert();  
  285.                 menu();  
  286.             }  
  287.             else  
  288.             {  
  289.                 printf("链表为空,请先建立链表!/n");  
  290.                 menu();  
  291.             }  
  292.             break;  
  293.         case 6:  
  294.             if(head)  
  295.             {  
  296.                 ModifymusicInfo();  
  297.                 menu();  
  298.             }  
  299.             else  
  300.             {  
  301.                 printf("链表为空,请先建立链表!/n");  
  302.                 menu();  
  303.             }  
  304.             break;  
  305.         default:  
  306.             break;  
  307.         }  
  308.     }  
  309.     system("pause");  
  310.     return 0;  
  311. }  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值