歌厅歌曲管理系统

news/2024/11/28 0:39:27/

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

完整的实现代码如下:

[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. }  


http://www.ppmy.cn/news/841772.html

相关文章

KTV歌曲管理系统

歌曲管理系统---实现读、写文件中的歌曲信息、浏览、排序、查找、删除歌曲等功能。 [cpp:firstline[0]] view plain copy print ? #include "stdio.h" #include "stdlib.h" #include "malloc.h" #include "string.h" int i0…

MyBatis 中如何使用缓存

MyBatis 中如何使用缓存 MyBatis 是一个基于 Java 的持久层框架&#xff0c;它提供了多种方式来使用缓存&#xff0c;包括一级缓存和二级缓存。本文将介绍 MyBatis 中常见的缓存使用方式及其使用方法。 1. 一级缓存 MyBatis 中的一级缓存是指 SqlSession 的缓存&#xff0c;它…

有哪些比较好用的供应链管理系统?供应链系统好用的5大准则

阅读本文您将了解&#xff1a;1.什么是供应链管理系统&#xff1b;2.供应链管理系统主要解决哪些问题&#xff1b;3.有哪些比较好用的供应链管理系统&#xff1b;4.供应链管理系统的选择标准。 一、什么是供应链管理系统&#xff1f; 供应链管理系统&#xff08;Supply Chain …

USB Typec转HDMI方案

USB Typec转HDMI方案-AG9310,AG9311,AG9320,AG9321,几款型号是Algoltek安格科技 针对USB TYPE-C扩展坞和USB TYPE-CUSB扩展器市场需求下&#xff0c;新开发的搞性价比的方案芯片。其参数性能对比如下图所示&#xff1a;

HDMI 1.4和HDMI 2.0区别

对于HDMI1.4和HDMI2.0的关系&#xff0c;在这里我们有两个内容要弄清楚&#xff1a; 第一&#xff0c;HDMI2.0标准向下兼容&#xff0c;这样就意味着所有旧的智能网络机顶盒或者是硬盘播放器能够与新款4K电视兼容。 第二&#xff0c;HDMI2.0电缆形状与HDMI1.4电缆完全没有区别…

绿联hdmi延长器

绿联hdmi延长器不错&#xff0c;对信号有明显的放大作用。 绿联的HDMI切换器对信号没有任何放大作用&#xff0c;即使带电源的。 转载于:https://www.cnblogs.com/sayweall/p/6902490.html

mipi 转HDMI

MIPI-DSI转HDMI驱动调试(lt8912) Overview 屏的接口种类非常多&#xff0c;常见的包括RGB、HDMI、VGA、LVDS、EDP、MIPI等接口。其中&#xff0c;在Android移动设备上&#xff0c;大多采用的是MIPI接口。某些时候&#xff0c;由于某种需求&#xff0c;需要将 Android设备上的…

HDMI 1.4 协议详解

HDMI系统架构定义为由源和接收器组成。给定的设备可能具有一个或多个HDMI输入和一个或多个HDMI输出。这些设备上的每个HDMI输入都应遵循HDMI接收器的所有规则&#xff0c;每个HDMI输出应遵循HDMI源的所有规则。 如图3-1所示&#xff0c;HDMI电缆和连接器带有四个差分对&#xf…