亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言通訊錄管理系統(tǒng)完整版

 更新時間:2020年05月25日 08:54:57   作者:hackbuteer1  
這篇文章主要為大家詳細介紹了C語言通訊錄管理系統(tǒng)的完整版本,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

C語言實現了通訊錄的錄入信息、保存信息、插入、刪除、排序、查找、單個顯示等功能。。

完整的代碼如下:

#include <stdio.h> 
#include <malloc.h> //得到指向大小為Size的內存區(qū)域的首字節(jié)的指針// 
#include <string.h> 
#include <stdlib.h> //標準庫函數// 
#define NULL 0 
#define LEN sizeof(struct address_list) //計算字節(jié)// 
int n; 
struct address_list 
{ 
 char name[30]; //名字 
 char work[30]; //職業(yè) 
 char handset[30]; //手機 
 char email[30]; //電子郵件 
 char address[30]; //通訊地址 
 struct address_list *next; 
}; 
struct address_list *shifang(struct address_list *head); // 釋放內存函數聲明 
//創(chuàng)建函數,不帶頭結點的鏈表 
struct address_list *creat(void)  
{ 
 struct address_list *head,*p1,*p2; 
 char name[20]; 
 n=0; 
 p1=(struct address_list *)malloc(LEN); 
 p2=p1; //強制內存轉換 
 printf("請輸入通訊錄的內容!\n姓名輸入為0時表示創(chuàng)建完畢!\n"); 
 printf("請輸入姓名:"); 
 gets(name); 
 if(strcmp(name,"0")!=0) 
 { 
 strcpy(p1->name,name); 
 printf("請輸入職業(yè):"); gets(p1->work); 
 printf("請輸入手機:"); gets(p1->handset); 
 printf("請輸入電子郵件:"); gets(p1->email); 
 printf("請輸入通訊地址:"); gets(p1->address); 
 head=NULL; 
 while(1) 
 { 
  n=n+1; //記錄通訊錄人數個數 
  if(n==1) 
  head=p1; 
  else 
  p2->next=p1; 
  p2=p1; 
  printf("請輸入姓名:"); 
  gets(name); 
  if(strcmp(name,"0")==0) 
  { 
  break; 
  } 
  else 
  { 
  p1=(struct address_list *)malloc(LEN); 
  strcpy(p1->name,name); 
  printf("請輸入職業(yè):"); gets(p1->work); 
  printf("請輸入手機:"); gets(p1->handset); 
  printf("請輸入電子郵件:"); gets(p1->email); 
  printf("請輸入通訊地址:"); gets(p1->address); 
  } 
 } 
 p2->next=NULL; 
 return head; 
 } 
 else 
 return 0; 
} 
//輸出函數 
void print(struct address_list *head) 
{ 
 struct address_list *p; 
 if(head!=NULL) 
 { 
 p=head; 
 printf("本通訊錄現在共有%d人:\n",n); 
 printf("---姓名-------職業(yè)--------手機-------Email-------通訊地址\n"); 
 printf("==================================\n"); 
 do 
 { 
  printf("== %s",p->name); printf(" "); 
  printf("%s",p->work); printf(" "); 
  printf("%s",p->handset); printf(" "); 
  printf("%s",p->email); printf(" "); 
  printf("%s",p->address); printf(" \n"); 
  p=p->next; 
 }while(p!=NULL); 
 printf("==================================\n"); 
 } 
 else 
 printf("通訊錄為空,無法輸出!\n"); 
} 
//增加函數 
struct address_list *insert(struct address_list *head) 
{ 
 struct address_list *p0,*p1,*p2; 
 char name[20]; 
 p1=head; 
 printf("請輸入增加的內容:\n"); 
 printf("請輸入姓名:"); gets(name); 
 if(strcmp(name,"0")==0) 
 { 
 printf("姓名不能為0,增加失敗!\n"); 
 return(head); 
 } 
 else 
 { 
 p0=(struct address_list *)malloc(LEN); 
 strcpy(p0->name,name); 
 printf("請輸入職業(yè):"); gets(p0->work); 
 printf("請輸入手機:"); gets(p0->handset); 
 printf("請輸入電子郵件:"); gets(p0->email); 
 printf("請輸入通訊地址:"); gets(p0->address); 
 n=n+1; 
 if(head==NULL) 
 { 
  head=p0; 
  p0->next=NULL; 
  return head; 
 } 
 else 
 { 
  while(strcmp(p0->name,p1->name)>0&&(p1->next!=NULL)) 
  { 
  p2=p1; 
  p1=p1->next; 
  } 
  if(strcmp(p0->name,p1->name)<0 || strcmp(p0->name,p1->name)==0) 
  { 
  if(head==p1) 
  { 
   head=p0; 
  } 
  else 
  { 
   p2->next=p0; 
  } 
  p0->next=p1; 
  } 
  else 
  { 
  p1->next=p0; 
  p0->next=NULL; 
  } 
  return head; 
 } 
 } 
} 
struct address_list* delete_txl(struct address_list *head) 
{ 
 struct address_list *p,*q; 
 char name[30]; 
 if(head==NULL) 
 { 
 printf("通訊錄為空,無法顯示!\n"); 
 return head; 
 } 
 p=head; 
 printf("請輸入需要刪除的人的姓名:"); 
 gets(name); 
 if(strcmp(head->name,name)==0) 
 { 
 head=head->next; 
 free(p); 
 printf("刪除操作成功!\n"); 
 return head; 
 } 
 else 
 { 
 q=head,p=head->next; 
 while(p!=NULL) 
 { 
  if(strcmp(p->name,name)==0) 
  { 
  q->next=p->next; 
  free(p); 
  printf("刪除操作成功!\n"); 
  return head; 
  } 
  p=p->next; 
  q=q->next; 
 } 
 } 
} 
//顯示函數 
struct address_list *display(struct address_list *head) 
{ 
 struct address_list *p1,*p2; 
 char name[30]; 
 int m; 
 if(head==NULL) 
 { 
 printf("通訊錄為空,無法顯示!\n"); 
 return head; 
 } 
 p1=head; 
 m=0; 
 printf("請輸入需要顯示人的姓名:"); 
 gets(name); 
 while(p1!=NULL) 
 { 
 while((strcmp(p1->name,name))!=0 && p1->next!=NULL) 
 { 
  p2=p1; 
  p1=p1->next; 
 } 
 if(strcmp(p1->name,name)==0) 
 { 
  m++; 
  printf("%s的通訊內容如下:\n",name); 
  printf("---姓名--------職業(yè)--------手機-------Email------通訊地址\n"); 
  printf("==================================\n"); 
  printf("== %s",p1->name);printf(" "); 
  printf("%s",p1->work);printf(" "); 
  printf("%s",p1->handset);printf(" "); 
  printf("%s",p1->email);printf(" "); 
  printf("%s",p1->address); printf(" \n"); 
  printf("==================================\n"); 
 } 
 p1=p1->next; 
 } 
 if(m==0) 
 { 
 printf("此人未在本通訊錄中!\n"); 
 } 
 return(head); 
} 
 
//排序函數 
struct address_list *paixu(struct address_list *head) 
{ 
 struct address_list *p1,*p2; 
 int i,j; 
 struct address_list1 
 { 
 char name[30]; 
 char work[30]; 
 char handset[30]; 
 char email[30]; 
 char address[30]; 
 }; 
 struct address_list1 px[200]; 
 struct address_list1 temp; 
 if(head==NULL) 
 { 
 printf("通訊錄為空,無法排序!\n"); 
 return(head); 
 } 
 p1=head; 
 for(i=0;i<n,p1!=NULL;i++) 
 { 
 strcpy(px[i].name,p1->name); 
 strcpy(px[i].work,p1->work); 
 strcpy(px[i].handset,p1->handset); 
 strcpy(px[i].email,p1->email); 
 strcpy(px[i].address,p1->address); 
 p2=p1; 
 p1=p1->next; 
 } 
 head=shifang(head); 
 for(j=0;j<n-1;j++) 
 { 
 for(i=j+1;i<n;i++) 
 { 
  if(strcmp(px[i].name,px[j].name)<0) 
  { 
  temp=px[i]; 
  px[i]=px[j]; 
  px[j]=temp; 
  } 
 } 
 } 
 p1=(struct address_list *)malloc(LEN); 
 p2=p1; 
 strcpy(p1->name,px[0].name); 
 strcpy(p1->work,px[0].work); 
 strcpy(p1->handset,px[0].handset); 
 strcpy(p1->email,px[0].email); 
 strcpy(p1->address,px[0].address); 
 
 head=p1; 
 for(i=1;i<n;i++) 
 { 
 p1=(struct address_list *)malloc(LEN); 
 strcpy(p1->name,px[i].name); 
 strcpy(p1->work,px[i].work); 
 strcpy(p1->handset,px[i].handset); 
 strcpy(p1->email,px[i].email); 
 strcpy(p1->address,px[i].address); 
 p2->next=p1; 
 p2=p1; 
 } 
 p2->next=NULL; 
 printf("按姓名排序后為:\n"); 
 print(head); 
 return(head); 
} 
//姓名查找函數 
struct address_list *search(struct address_list *head) 
{ 
 struct address_list *p1,*p2; 
 int m; 
 char name[30]; 
 if(head==NULL) 
 { 
 printf("通訊錄為空,無法分類查找!\n"); 
 return(head); 
 } 
 p1=head; 
 printf("********************\n"); 
 printf("** 請輸入需要查找的姓名 **\n"); 
 printf("********************\n"); 
 m=0; 
 gets(name); 
 while(p1!=NULL) 
 { 
 while(strcmp(p1->name,name)!=0&&p1->next!=NULL) 
 { 
  p2=p1; 
  p1=p1->next; 
 } 
 if(strcmp(p1->name,name)==0) 
 { 
  m++; 
  printf("你查找的內容是:\n"); 
  printf("+++++++++++++++++++++++++++++++++++\n"); 
  printf("++ %s %s %s %s %s\n",p1->name,p1->work,p1->handset,p1->email,p1->address); 
  printf("+++++++++++++++++++++++++++++++++++\n"); 
 } 
 p1=p1->next; 
 
 if(m==0) 
 { 
  printf("此人未在本通訊錄中!\n"); 
 } 
 break; 
 } 
 
 return(head); 
} 
 
//釋放內存函數 
struct address_list *shifang(struct address_list *head) 
{ 
 struct address_list *p1; 
 while(head!=NULL) 
 { 
 p1=head; 
 head=head->next; 
 free(p1); 
 } 
 return(head); 
} 
 
//文件寫入函數 
void save(struct address_list *head) 
{ 
 FILE *fp; 
 struct address_list *p1; 
 char tong[30]; 
 if(head==NULL) 
 { 
 printf("通訊錄為空,無法存儲!\n"); 
 return; 
 } 
 printf("請輸入保存后的文件名:"); 
 gets(tong); 
 fp=fopen("(tong).txt","w"); 
 if(fp==NULL) 
 { 
 printf("cannot open file\n"); 
 return; 
 } 
 p1=head; 
 fprintf(fp,"姓名 職業(yè) 手機 Email 通訊地址\n"); 
 for(;p1!=NULL;) 
 { 
 fprintf(fp,"%s %s %s %s %s\n",p1->name,p1->work,p1->handset,p1->email,p1->address); 
 p1=p1->next; 
 } 
 printf("保存完畢!\n"); 
 fclose(fp); 
} 
 
//文件讀出函數 
struct address_list *load(struct address_list *head) 
{ 
 FILE *fp; 
 char tong[30]; 
 struct address_list *p1,*p2; 
 printf("請輸入要輸出的文件名:"); 
 gets(tong); 
 fp=fopen("(tong).txt","r"); 
 if(fp==NULL) 
 { 
 printf("此通訊錄名不存在,無法輸出!\n"); 
 return(head); 
 } 
 else 
 { 
 head=shifang(head); 
 } 
 p1=(struct address_list *)malloc(LEN); 
 fscanf(fp,"%s%s%s%s%s",&p1->name,&p1->work,&p1->handset,&p1->email,&p1->address); 
 if(feof(fp)!=0) 
 { 
 printf("文件為空,無法打開!\n"); 
 return(head); 
 } 
 else 
 { 
 rewind(fp); 
 p2=p1; 
 head=p1; 
 n=0; 
 while(feof(fp)==0) 
 { 
  fscanf(fp,"%s%s%s%s%s",&p1->name,&p1->work,&p1->handset,&p1->email,&p1->address); 
  if(feof(fp)!=0) 
  break; 
  p2->next=p1; 
  p2=p1; 
  p1=(struct address_list *)malloc(LEN); 
  n=n+1; 
 } 
 p2->next=NULL; 
 p1=head; 
 head=head->next; 
 n=n-1; 
 free(p1); 
 print(head); 
 printf("打開完畢!\n"); 
 return(head); 
 } 
 fclose(fp); 
} 
 
//綜合操作函數 
struct address_list *menu(struct address_list *head) 
{ 
 char num[10]; 
 while(1) 
 { 
 printf("*********************\n"); 
 printf("*** 1 姓名查找 ****\n"); 
 printf("*** 2 單個顯示 ****\n"); 
 printf("*** 3 增加  ****\n"); 
 printf("*** 4 退出  ****\n"); 
 printf("*********************\n"); 
 printf("請輸入您選擇的操作:"); 
 gets(num); 
 switch(*num) 
 { 
 case '1': 
  { 
  head=search(head);    //姓名查找 
  print(head); 
  } 
  break; 
 case '2': 
  { 
  head=display(head);    //顯示 
  } 
  break; 
 case '3': 
  { 
  head=insert(head);    //增加 
  print(head); 
  } 
  break; 
 case '4': 
  return head; 
 default: 
  printf("操作錯誤,此項不存在!\n"); 
  break; 
 } 
 if(strcmp(num,"6")==0) 
  break; 
 } 
 return head; 
} 
//主函數 
void main() 
{ 
 struct address_list *head=NULL; 
 char num[10]; 
 printf("*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*\n"); 
 printf("*=*  程序說明  *=*\n"); 
 printf("*=* 請及時保存創(chuàng)建完畢的通訊錄內容! *=*\n"); 
 printf("*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*\n"); 
 while(1) 
 { 
 printf("************************\n"); 
 printf("*** 1 創(chuàng)建通訊錄 ****\n"); 
 printf("*** 2 按名字排序 ****\n"); 
 printf("*** 3 綜合操作 ****\n"); 
 printf("*** 4 保存  ****\n"); 
 printf("*** 5 打開  ****\n"); 
 printf("*** 6 刪除  ****\n"); 
 printf("*** 7 退出  ****\n"); 
 printf("************************\n"); 
 printf("請輸入您選擇的操作:"); 
 gets(num); 
 switch(*num) 
 { 
 case '1': 
  { 
  if(head==NULL) 
  { 
   head=creat();    //創(chuàng)建 
   print(head); 
  } 
  else 
  { 
   head=shifang(head); 
   head=creat();    //重新創(chuàng)建 
   print(head); 
  } 
  } 
  break; 
 case '2': 
  { 
  head=paixu(head);    //排序 
  } 
  break; 
 case '3': 
  { 
  head=menu(head);    //綜合操作 
  } 
  break; 
 case '4': 
  { 
  save(head);     //文件保存 
  print(head); 
  } 
  break; 
 case '5': 
  { 
  head=load(head);    //文件輸出 
  } 
  break; 
 case '6': 
  { 
  head=delete_txl(head);    //刪除 
  print(head); 
  } 
  break; 
 case '7': 
  head=shifang(head); 
  break; 
 default: 
  printf("操作錯誤,此項不存在!\n"); 
  break; 
 } 
 if(strcmp(num,"7")==0) 
  break; 
 } 
}

更多學習資料請關注專題《管理系統(tǒng)開發(fā)》。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C/C++語言八大排序算法之桶排序全過程示例詳解

    C/C++語言八大排序算法之桶排序全過程示例詳解

    這篇文章主要為大家介紹了C/C++語言八大排序算法之桶排序算法過程的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2021-11-11
  • 在Visual Studio 2019中修改項目名的方法

    在Visual Studio 2019中修改項目名的方法

    這篇文章主要介紹了在Visual Studio 2019中修改項目名的方法,文中通過示例介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • C語言實現貪吃蛇小游戲開發(fā)

    C語言實現貪吃蛇小游戲開發(fā)

    這篇文章主要為大家詳細介紹了C語言實現貪吃蛇小游戲開發(fā),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C語言、C++內存對齊問題詳解

    C語言、C++內存對齊問題詳解

    這篇文章主要介紹了C語言、C++內存對齊問題詳解,內存對齊的問題主要存在于理解struct和union等復合結構在內存中的分布,需要的朋友可以參考下
    2014-10-10
  • C語言與C++中關于字符串使用的比較

    C語言與C++中關于字符串使用的比較

    字符串是我們再熟悉不過的東西了,任何語言中字符串都是基礎都要經常用到,那么在不同語言中字符串的用法一樣嗎?下面我們來看看C語言與C++中字符串使用的比較
    2022-05-05
  • C語言超詳細講解順序表的各種操作

    C語言超詳細講解順序表的各種操作

    大家好,今天給大家?guī)淼氖琼樞虮?,我覺得順序表還是有比較難理解的地方的,于是我就把這一塊的內容全部整理到了一起,希望能夠給剛剛進行學習數據結構的人帶來一些幫助,或者是已經學過這塊的朋友們帶來更深的理解,我們現在就開始吧
    2022-05-05
  • C語言基礎雙指針移除元素解法

    C語言基礎雙指針移除元素解法

    這篇文章介紹了C語言基礎雙指針移除元素的解法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • C語言的基本語法詳解

    C語言的基本語法詳解

    本篇文章主要講解C語言 基本語法,這里提供簡單的示例和代碼來詳細講解C語言的基本語法,開始學習C語言的朋友可以看一下,希望能夠給你帶來幫助
    2021-09-09
  • C++11學習之包裝器解析

    C++11學習之包裝器解析

    function包裝器?也叫作適配器。C++中的function本質是一個類模板,也是一個包裝器。本文就來和大家聊聊我們?yōu)槭裁葱枰猣unction呢
    2023-02-02
  • C++中變量的類型與作用域學習教程

    C++中變量的類型與作用域學習教程

    這篇文章主要介紹了C++中變量的類型與作用域,C++是面向對象的編程語言,一定要注意局部變量與全局變量的作用范圍,需要的朋友可以參考下
    2016-05-05

最新評論