欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言實現(xiàn)歌曲信息管理系統(tǒng)

 更新時間:2018年01月18日 09:48:58   作者:hackbuteer1  
這篇文章主要為大家詳細介紹了C語言實現(xiàn)歌曲信息管理系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現(xiàn)歌曲信息管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下

系統(tǒng)功能:該系統(tǒng)以菜單方式工作,歌曲信息包括:歌名、演唱者、作詞、作曲、所屬專輯、出版時間、出版公司。試設(shè)計一歌廳歌曲管理系統(tǒng),使之能提供以下功能:歌曲信息錄入、修改、插入、刪除功能;歌曲排序瀏覽功能;按歌名查詢、按演唱者查詢等功能。

完整的實現(xiàn)代碼如下:

#include "stdio.h" 
#include "stdlib.h" 
#include "string.h" 
//歌曲信息包括:歌名、演唱者、作詞、作曲、所屬專輯、出版時間、出版公司 
typedef struct music 
{ 
  char name[20];  //歌名 
  char singer[20]; //演唱者 
  char authors[20]; //作詞 
  char compose[30]; //作曲 
  char album[20];  //所屬專輯 
  char time[15];  //出版時間 
  char company[30]; //出版公司 
  struct music *next; 
}music; 
music *head=NULL; 
int length;  //鏈表的長度 
void create() 
{ 
  music *p1,*p2; 
  length=0; 
  p1=(music *)malloc(sizeof(music)); 
  strcpy(p1->name,"-1"); 
  if(head==NULL) 
    head=p1; 
  printf("請輸入音樂的歌名、演唱者、作詞、作曲、所屬專輯、出版時間、出版公司:/n"); 
  while(1) //歌名為0的時候退出 
  { 
    p2=(music *)malloc(sizeof(music)); 
    //輸入歌曲信息 
    scanf("%s %s %s %s %s %s %s",p2->name,p2->singer,p2->authors,p2->compose,p2->album,p2->time,p2->company); 
    if(strcmp(p2->name,"0")==0) 
    { 
      printf("鏈表創(chuàng)建完成!/n"); 
      break; 
    } 
    length++; //鏈表的長度 
    p1->next=p2; 
    p2->next=NULL; 
    p1=p1->next; 
  } 
  return ; 
} 
void ModifymusicInfo() 
{ 
  music *p=head->next; 
  char name[20]; 
  printf("請輸入要修改的歌曲的歌名:"); 
  getchar(); 
  scanf("%s",name); 
  while(p!=NULL) 
  { 
    if(strcmp(p->name,name)==0) 
    { 
      printf("修改前,歌名為%s的歌曲的信息如下:/n",name); 
      printf("音樂的歌名、演唱者、作詞、作曲、所屬專輯、出版時間、出版公司:/n"); 
      printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company); 
      printf("請輸入歌曲的新的所屬專輯:"); 
      getchar(); 
      scanf("%s",p->album); 
      printf("請輸入歌曲的新出版公司:"); 
      getchar(); 
      scanf("%s",p->company); 
      printf("修改后,歌名為%s的歌曲的信息如下:/n",name); 
      printf("音樂的歌名、演唱者、作詞、作曲、所屬專輯、出版時間、出版公司:/n"); 
      printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company); 
      return ; 
    } 
    p=p->next; 
  } 
  if(p==NULL) 
  { 
    printf("該歌曲不存在!/n"); 
    return ; 
  } 
} 
 
void display() 
{ 
  music *p=head->next; 
  printf("鏈表中所有的歌曲信息如下:/n"); 
  printf("音樂的歌名、演唱者、作詞、作曲、所屬專輯、出版時間、出版公司:/n"); 
  while(p!=NULL) 
  { 
    printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company); 
    p=p->next; 
  } 
  return ; 
} 
void search() 
{ 
  int num,x,flag; 
  char name[20]; 
  music *p=head->next; 
  printf("請選擇查詢的方式:/n"); 
  printf("1、按歌名查詢/t 2、按演唱者查詢/n"); 
  scanf("%d",&x); 
  if(x==1) 
  { 
    printf("需要查找的歌曲歌名為:"); 
    getchar(); 
    scanf("%s",name); 
    while(p!=NULL) 
    { 
 
      if(strcmp(p->name,name)==0) 
      { 
        printf("歌名為%s的歌曲的信息如下:/n",name); 
        printf("音樂的歌名、演唱者、作詞、作曲、所屬專輯、出版時間、出版公司:/n"); 
        printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company); 
        return ; 
      }   
      p=p->next; 
    } 
    if(p==NULL) 
      printf("沒有這首歌曲的記錄!/n"); 
  } 
  else if(x==2) 
  { 
    flag=0; 
    printf("需要查找的演唱者為:"); 
    getchar(); 
    scanf("%s",name); 
    p=head->next; 
    while(p!=NULL) 
    { 
      if(strcmp(p->singer,name)==0) 
      { 
        if(flag==0) 
        { 
          printf("演唱者為%s的歌曲的信息如下:/n",name); 
          printf("音樂的歌名、演唱者、作詞、作曲、所屬專輯、出版時間、出版公司:/n"); 
          flag=1; 
        } 
        printf("%s %s %s %s %s %s %s/n",p->name,p->singer,p->authors,p->compose,p->album,p->time,p->company); 
      }   
      p=p->next; 
    } 
    if(p==NULL && flag==0) 
    { 
      printf("沒有該演唱者的歌曲記錄!/n"); 
      return; 
    } 
  } 
  return ; 
} 
 
void insert() 
{ 
  int num,i; 
  music *p,*q; 
  p=head; 
 
  printf("請輸入你要插入位置: "); 
  scanf("%d",&num); 
  if(num>length) 
  { 
    printf("找不到要插入的位置/n"); 
    return ; 
  } 
  else 
  { 
    printf("請輸入你要插入的音樂的歌名、演唱者、作詞、作曲、所屬專輯、出版時間、出版公司:/n"); 
    q=(music *)malloc(sizeof(music)); 
    //輸入歌曲信息 
    scanf("%s %s %s %s %s %s %s",q->name,q->singer,q->authors,q->compose,q->album,q->time,q->company); 
    while(p!=NULL) 
    { 
      if(strcmp(p->name,q->name)==0) 
      { 
        printf("該歌曲已經(jīng)存在,無法插入!/n"); 
        return ; 
      } 
      p=p->next; 
    } 
    p=head; 
    for(i=0;i<num;i++) 
      p=p->next; 
    q->next=p->next; 
    p->next=q; 
    length++; 
    printf("插入成功!/n"); 
    return ; 
  } 
}  
 
void Delete() 
{ 
  char name[20]; 
  music *p,*q; 
  q=head,p=head->next; 
  printf("請輸入要刪除的歌曲的歌名:/n"); 
  getchar(); 
  scanf("%s",name); 
 
  while(p!=NULL) 
  { 
    if(strcmp(p->name,name)==0) 
    { 
      q->next=p->next; 
      free(p); 
      length--; 
      printf("刪除成功!/n"); 
      return ; 
    } 
    p=p->next; 
    q=q->next; 
  } 
  if(p==NULL) 
  { 
    printf("找不到要刪除的歌曲!/n"); 
    return ; 
  } 
} 
void menu() 
{ 
  printf("________________________________________________________________/n"); 
  printf("|       歌廳歌曲管理系統(tǒng)                |/n"); 
  printf("|        0、 退出系統(tǒng)                  |/n"); 
  printf("|        1、 錄入歌曲信息                |/n"); 
  printf("|        2、 顯示歌曲信息                |/n"); 
  printf("|        3、 查找鏈表中的某一首歌曲           |/n"); 
  printf("|        4、 刪除鏈表中指定歌曲             |/n"); 
  printf("|        5、 指定的位置上插入一個新結(jié)點         |/n"); 
  printf("|        6、 修改歌曲信息                |/n"); 
  printf("________________________________________________________________/n"); 
  return ; 
} 
int main(void) 
{ 
  int a; 
  menu(); 
  while(1) 
  { 
    printf("請選擇相應(yīng)的功能:"); 
    scanf("%d",&a); 
    switch(a) 
    { 
    case 0: 
      return 0; 
    case 1: 
      create(); 
      menu(); 
      break; 
    case 2: 
      if(head) 
      { 
        display(); 
        menu(); 
      } 
      else 
      { 
        printf("鏈表為空,請先建立鏈表!/n"); 
        menu(); 
      } 
      break; 
    case 3: 
      if(head) 
      { 
        search(); 
        menu(); 
      } 
      else 
      { 
        printf("鏈表為空,請先建立鏈表!/n"); 
        menu(); 
      } 
      break; 
    case 4: 
      if(head) 
      { 
        Delete(); 
        menu(); 
      } 
      else 
      { 
        printf("鏈表為空,請先建立鏈表!/n"); 
        menu(); 
      } 
      break; 
    case 5: 
      if(head) 
      { 
        insert(); 
        menu(); 
      } 
      else 
      { 
        printf("鏈表為空,請先建立鏈表!/n"); 
        menu(); 
      } 
      break; 
    case 6: 
      if(head) 
      { 
        ModifymusicInfo(); 
        menu(); 
      } 
      else 
      { 
        printf("鏈表為空,請先建立鏈表!/n"); 
        menu(); 
      } 
      break; 
    default: 
      break; 
    } 
  } 
  system("pause"); 
  return 0; 
} 

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • c++讀取excel的代碼詳解

    c++讀取excel的代碼詳解

    在本篇文章里小編給大家分享的是一篇關(guān)于c++讀取excel的代碼詳解內(nèi)容,需要的朋友們可以學(xué)習(xí)參考下。
    2020-02-02
  • C語言背包問題求解全過程(貪心方法)

    C語言背包問題求解全過程(貪心方法)

    背包問題是一個經(jīng)典的動態(tài)規(guī)劃問題,而貪心算法是一種常用的解決背包問題的方法,這篇文章主要給大家介紹了關(guān)于C語言背包問題求解(貪心方法)的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-06-06
  • 詳解C語言中結(jié)構(gòu)體的使用

    詳解C語言中結(jié)構(gòu)體的使用

    結(jié)構(gòu)體是一些值的集合,這些值稱為成員變量,結(jié)構(gòu)體的每個成員可以是不同類型的變量。本文將通過示例為大家詳細講講C語言中結(jié)構(gòu)體的使用,需要的可以參考一下
    2022-07-07
  • QT實現(xiàn)單詞檢索軟件的示例代碼

    QT實現(xiàn)單詞檢索軟件的示例代碼

    本文主要介紹了QT實現(xiàn)單詞檢索軟件的示例代碼,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C語言數(shù)據(jù)結(jié)構(gòu)與算法之圖的遍歷(二)

    C語言數(shù)據(jù)結(jié)構(gòu)與算法之圖的遍歷(二)

    這篇文章主要是介紹了利用廣度優(yōu)先算法實現(xiàn)圖的遍歷,文中利用圖文詳細的介紹了實現(xiàn)步驟,對我們學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)與算法有一定的幫助,需要的朋友可以參考一下
    2021-12-12
  • C語言中等待socket連接和對socket定位的方法

    C語言中等待socket連接和對socket定位的方法

    這篇文章主要介紹了C語言中等待socket連接和對socket定位的方法,分別為listen()函數(shù)和bind()函數(shù)的用法,需要的朋友可以參考下
    2015-09-09
  • C++?Protobuf的學(xué)習(xí)使用指南

    C++?Protobuf的學(xué)習(xí)使用指南

    protocol?buffers是一種語言無關(guān)、平臺無關(guān)、可擴展的序列化結(jié)構(gòu)數(shù)據(jù)的方法,它可用于(數(shù)據(jù))通信協(xié)議、數(shù)據(jù)存儲等,下面就來跟隨小編一起簡單學(xué)習(xí)一下它的使用吧
    2023-07-07
  • c語言冒泡排序和選擇排序的使用代碼

    c語言冒泡排序和選擇排序的使用代碼

    算法中排序是十分重要的,而每一個學(xué)習(xí)計算機的都會在初期的時候接觸到這種排序,下面這篇文章主要給大家介紹了關(guān)于c語言冒泡排序和選擇排序使用的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • C語言形參與實參使用的差別講解

    C語言形參與實參使用的差別講解

    形參出現(xiàn)在函數(shù)定義中,在整個函數(shù)體內(nèi)都可以使用, 離開該函數(shù)則不能使用。實參出現(xiàn)在主調(diào)函數(shù)中,進入被調(diào)函數(shù)后,實參變量也不能使用,形參和實參的功能是作數(shù)據(jù)傳送。發(fā)生函數(shù)調(diào)用時, 主調(diào)函數(shù)把實參的值傳送給被調(diào)函數(shù)的形參從而實現(xiàn)主調(diào)函數(shù)向被調(diào)函數(shù)的數(shù)據(jù)傳送
    2023-02-02
  • C語言實現(xiàn)最小生成樹構(gòu)造算法

    C語言實現(xiàn)最小生成樹構(gòu)造算法

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)最小生成樹構(gòu)造算法,利用Prim算法或kruskal算法求解,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01

最新評論