1. 程式人生 > 程式設計 >C語言實現電話簿管理系統

C語言實現電話簿管理系統

本文例項為大家分享了C語言電話簿管理系統的具體程式碼,供大家參考,具體內容如下

/*大二實踐周所作,
時間:2017.9,11
電話簿管理系統
*/
 
#include<string.h>
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
#define NULL 0
typedef struct lianxiren{
 char job[30];
 char number[20];
 char name[10];
 char email[30];
 struct lianxiren*next;
}lianxiren;
#define LEN sizeof(lianxiren)
lianxiren* creat_list()
{
 lianxiren *head,*p1,*p2;
 char name[10];int n=0;
 head=NULL;
 p1=(lianxiren *)malloc(LEN);
 p2=p1;
 printf("請輸入姓名(姓名為0時停止建立):");
 gets(name);
 if(strcmp(name,"0")==0)return 0;
 else {
 strcpy(p1->name,name);
 printf("請輸入電話號碼:");gets(p1->number);
 printf("請輸入工作單位:");gets(p1->job);
 printf("請輸入E-mail:");gets(p1->email);
 }
 while(1)
 {
 n++;
 if(n==1)
  head=p1;
 else
  p2->next=p1;
 p2=p1;
 printf("請輸入姓名(姓名為0時停止建立):");
 gets(name);
 if(strcmp(name,"0")==0)break;
 else{
  p1=(lianxiren*)malloc(LEN);
      strcpy(p1->name,name);
  printf("請輸入電話號碼:");gets(p1->number);
  printf("請輸入工作單位:");gets(p1->job);
  printf("請輸入E-mail:");gets(p1->email);}
 }p2->next=NULL;
 return head;
}//連結串列建立函式
lianxiren* shifang_list(lianxiren*head)
{
 lianxiren*p1;
 for(;head!=NULL;)
 {
 p1=head; 
 head=head->next; 
 free(p1);
 }
 return head;
}//釋放連結串列函式
void print_list(lianxiren*head)
{
 void caidan();
 int n=0;
 printf("現在通訊錄中有如下成員:");
  while(head!=NULL)
 {
 printf("\n名字:");puts(head->name);
 printf("\n電話號碼:");puts(head->number);
 printf("\n工作單位:");puts(head->job);
 printf("\nE-mail:");puts(head->email);
 putchar('\n');
 head=head->next;n++;
 if(n%8==0){
 printf("按回車鍵顯示下一頁");
 getchar();
 system("cls");
 caidan();
 } 
 }
 printf("總共%d個聯絡人\n",n);
}//列印連結串列函式
int length(lianxiren*head) 
{ 
  int n = 0; 
  lianxiren *p; 
  p = head; 
  while(p != NULL) 
  { 
    p = p->next; 
    n++; 
  } 
  return n; 
} 
 
void paixu1(lianxiren*head)
{
 void caidan();
 int n=length(head);
 int i,j;
 lianxiren temp,*p;
 p=head;
 lianxiren a[100];
 for(i=1;i<=n;i++)
 {
 strcpy(a[i].name,p->name);
 strcpy(a[i].number,p->number);
 strcpy(a[i].job,p->job);
 strcpy(a[i].email,p->email);
 p=p->next;
 }
 for(i=1;i<=n-1;i++)
 {
 for(j=1;j<=n-i;j++)
 {if(strcmp(a[j].number,a[j+1].number)>0)
 {
  temp=a[j];
      a[j]=a[j+1];
  a[j+1]=temp;
 } 
 }
 }
 printf("現在通訊錄中有如下成員:");
 for(i=1;i<=n;i++)
 {
 printf("\n名字:");puts(a[i].name);
 printf("\n電話號碼:");puts(a[i].number);
 printf("\n工作單位:");puts(a[i].job);
 printf("\nE-mail:");puts(a[i].email);
 putchar('\n');
 if(i%8==0){
 printf("按回車鍵顯示下一頁");
 getchar();
 system("cls");
 caidan();
 } 
 }
 printf("總共%d個聯絡人\n",n);
}
void paixu2(lianxiren*head)
{
 void caidan();
 int n=length(head);int i,p->email);
 p=p->next;
 }
for(i=1;i<=n-1;i++)
 {
 for(j=1;j<=n-i;j++)
 {if(strcmp(a[j].name,a[j+1].name)>0)
 {
  temp=a[j];
      a[j]=a[j+1];
  a[j+1]=temp;
 } 
 }
 }
 printf("現在通訊錄中有如下成員:");
 for(i=1;i<=n;i++)
 {
 printf("\n名字:");puts(a[i].name);
 printf("\n電話號碼:");puts(a[i].number);
 printf("\n工作單位:");puts(a[i].job);
 printf("\nE-mail:");puts(a[i].email);
 putchar('\n');
 if(i%8==0){
 printf("按回車鍵顯示下一頁");
 getchar();
 system("cls");
 caidan();
 } 
 }
 printf("總共%d個聯絡人\n",n);
}
void paixu_list(lianxiren*head)
{
 void caidan();
 if(head==NULL)
 {printf("電話簿為空,請重新建立!");
 return;
 }
 char a;
 printf("1,按電話號碼升序排序\n2,按姓名字母升序排序\n");
 printf("請選擇一種排序方法:");
 a=getchar();
 getchar();
 switch(a){
 case'1':paixu1(head);break;
 case'2':paixu2(head);break;
 default:printf("輸入有誤!\n");break;
 }
}
void chazhao1(lianxiren*head)
{if(head==NULL)
{
 printf("電話簿為空,請重新建立");
 return;
}
char name[10];
printf("請輸入名字:");gets(name);
while(strcmp(name,head->name)!=0)
{head=head->next;
if(head==NULL){printf("電話簿未有此聯絡人\n");
return;}
}
printf("%s的電話號碼為:",name);
puts(head->number);
printf("\n工作單位:");puts(head->job);
printf("\nE-mail:");puts(head->email);
}//通過名字查詢
void chazhao2(lianxiren*head)
{if(head==NULL)
{
 printf("電話簿為空,請重新建立");
 return;
}
char number[20];
printf("請輸入電話號碼:");gets(number);
while(strcmp(number,head->number)!=0)
{head=head->next;
if(head==NULL){printf("電話簿未有此聯絡人\n");
return;}
}
printf("%s的主人為:",number);
puts(head->name);
printf("\n工作單位:");puts(head->job);
printf("\nE-mail:");puts(head->email);
}//通過電話號碼查詢
void chazhao(lianxiren*head)
{
 int n;
 printf("  1,通過名字查詢\n  2,通過電話號碼查詢\n  3,退出\n請選擇你需要的服務:");
  scanf("%d",&n);
 getchar();
 while(1)
 {
 switch(n){
 case 1:{chazhao1(head);printf("請選擇服務項:");scanf("%d",&n);getchar();}break;
 case 2:{chazhao2(head);printf("請選擇服務項:");scanf("%d",&n);getchar();}break;
 case 3:return;break;
 default:{printf("輸入不正確!");printf("請選擇服務項:");scanf("%d",&n);getchar();}break;
 }}
}//查詢聯絡人
void add_list(lianxiren*head)
{
  lianxiren*p1,*p2,*h;
 char name[10];
 printf("請輸入名字(名字為0時停止)");
 gets(name);
 if(strcmp(name,"0")!=0)
 {
 p1=(lianxiren*)malloc(LEN);
 strcpy(p1->name,name);
 printf("請輸入電話號碼:");gets(p1->number);
 printf("請輸入工作單位:");gets(p1->job);
 printf("請輸入E-mail:");gets(p1->email);
 }
 else return;
 h=p1;
  while(1)
 {
 p2=p1;
 printf("請輸入名字(名字為0時停止)");
 gets(name);
 if(strcmp(name,"0")==0)break;
 else{
  p1=(lianxiren*)malloc(LEN);
  strcpy(p1->name,name);
  printf("請輸入電話號碼:");gets(p1->number);
  printf("請輸入工作單位:");gets(p1->job);
  printf("請輸入E-mail:");gets(p1->email);
  p2->next=p1;
 }
 }
  p1=head->next;
 head->next=h;
  p2->next=p1;
}//新增連結串列函式
lianxiren*xiugai_list(lianxiren*head)
{
 char a[20];
 printf("請輸入聯絡人名字或電話:");
 gets(a);
 if(head==NULL)
 {
 printf("電話簿為空,請重新建立");
 return head;
 }
 lianxiren*p=head;
 while(strcmp(a,p->name)!=0&&strcmp(a,p->number)!=0)
 {
 p=p->next;
 if(p==NULL){printf("電話簿未有此聯絡人\n");
 return head;}
 }
 printf("查詢到了!");
 printf("\n名字:");puts(p->name);
 printf("\n電話號碼:");puts(p->number);
 printf("\n工作單位:");puts(p->job);
 printf("\nE-mail:");puts(p->email);
 putchar('\n');
 int n;
 while(1)
 {printf("請選擇操作項(1,名字2,電話號碼3,工作單位4,E-mail 5,退出):");
 scanf("%d",&n);
 getchar();
 switch(n)
 {
  case 1:{printf("請輸入名字:");gets(p->name);}break;
 case 2:{printf("請輸入電話號碼:");gets(p->number);}break;
 case 3:{printf("請輸入工作單位:");gets(p->job);}break;
 case 4:{printf("請輸入E-mail:");gets(p->email);}break;
  case 5:return head;break;
 default:printf("輸入錯誤!");break;
 }
 }
}//修改連結串列函式
lianxiren*delete_list(lianxiren*head)
{
 char a[20];
 printf("請輸入聯絡人名字或電話:");
 gets(a);
 if(head==NULL)
 {
 printf("電話簿為空,請重新建立");
 return head;
 }
 lianxiren*p=head,*p1;
 while(strcmp(a,p->number)!=0)
 {
 p1=p;
 p=p->next;
 if(p==NULL){printf("電話簿未有此聯絡人\n");
 return head;}
 }
 printf("查詢到了!");
 printf("\n名字:");puts(p->name);
 printf("\n電話號碼:");puts(p->number);
 printf("\n工作單位:");puts(p->job);
 printf("\nE-mail:");puts(p->email);
 putchar('\n');
 char n;
 printf("是否刪除該聯絡人(Y/N)");
 n=getchar();
 switch(n)
 {
  case 'y':
 case 'Y':{if(p==head){head=p->next;free(p);}else{p1->next=p->next;free(p);}printf("成功刪除!");}break;
 case 'N':
 case 'n':printf("取消刪除!");break;
 default:printf("輸入錯誤!");break;
 }
 return head;
}//刪除連結串列函式
void save_list(lianxiren*head)
{FILE *fp;
if((fp=fopen("dianhuabu.dat","wb"))==NULL) {
 printf("File cannot be opened\n");
 exit(0);}
if(head==NULL)
{
 printf("通訊錄為空\n");
 return;
}
lianxiren*p1=head;
while(p1!=NULL)
{
 if(fwrite(p1,LEN,1,fp)!=1){
 printf("cannot open file\n");
 return;}
 p1=p1->next;
}
printf("儲存完畢!\n");
fclose(fp);
}//檔案寫入函式
lianxiren*load_list(lianxiren*head)
{FILE *fp;
if((fp=fopen("dianhuabu.dat","rb"))==NULL) {
 printf("電話簿為空,請重新建立\n");
 exit(0);}
lianxiren*p1,*p2;
p1=(lianxiren*)malloc(LEN);
if(fread(p1,fp)==0)
{printf("電話簿為空,請重新建立");
return head;
}
head=p1;
p2=p1;
p1=(lianxiren*)malloc(LEN);
while(fread(p1,fp))
{
 p2->next=p1;
 p2=p1;
 p1=(lianxiren*)malloc(LEN);
}
p2->next=NULL;
free(p1);
return(head);
fclose(fp);
}//檔案讀取函式
int kouling()
{
 char s[20];
 printf("請輸入口令:");
 int n=0;
 while(n<3)
 {scanf("%s",s);
 getchar();
 if(strcmp(s,"20160390527")==0)
 return 0;
 else{n++;
 if(n==3){
 printf("抱歉,輸入錯誤\n");
 return 1;}
 printf("口令錯誤,請重新輸入\n");
 }
 }return 1;
}//口令驗證,密碼為:20160390527
void caidan()
{
 printf("      歡迎進入電話簿系統      \n");
 printf("********************************************\n");
  printf("    1、建立電話簿(會將原有電話簿覆蓋)\n");
 printf("    2、查詢聯絡人        \n");
 printf("    3、新增聯絡人        \n");
 printf("    4、修改聯絡人        \n");
 printf("    5、刪除聯絡人        \n");
  printf("    6、檢視電話簿(排序)     \n");
 printf("    7、退出系統         \n");
 printf("********************************************\n");
}//選單介面
void main()
{
 if(kouling()) return;//口令驗證
 system("cls");
 caidan();//進入選單介面
 printf("     請選擇你所需要的服務:");
 int n;scanf("%d",&n);
 getchar();
 lianxiren*head;
 while(1){
 system("cls");
    caidan();
 switch(n){
 case 1:{
  head=creat_list();
  system("cls");
  caidan();
  print_list(head);
  save_list(head);
  shifang_list(head);
  printf("********************************************\n");
  printf("\n如需要其他服務,請重新輸入:");
  scanf("%d",&n);
  getchar();}break;//建立電話簿(建立連結串列、寫入檔案,釋放連結串列)
 case 2:{
  head=load_list(head);
  chazhao(head);
  shifang_list(head);
  printf("********************************************\n");
  printf("\n如需要其他服務,請重新輸入:");
  scanf("%d",&n);
  getchar();}break;//查詢聯絡人(讀入檔案、查詢函式、釋放連結串列)
 case 3:{
  head=load_list(head);
  add_list(head);
  system("cls");
  caidan();
  print_list(head);
  save_list(head);
  shifang_list(head);
  printf("********************************************\n");
  printf("\n如需要其他服務,請重新輸入:");
  scanf("%d",&n);
  getchar();}break;//新增聯絡人(讀入檔案、新增連結串列、寫入檔案、釋放連結串列)
 case 4:{
  head=load_list(head);
  head=xiugai_list(head);
  save_list(head);
  shifang_list(head);
  printf("********************************************\n");
  printf("\n如需要其他服務,請重新輸入:");
  scanf("%d",&n);
  getchar();}break;//修改聯絡人(讀入檔案,修改連結串列、寫入檔案、釋放連結串列)
 case 5:{
  head=load_list(head);
  head=delete_list(head);
  save_list(head);
  shifang_list(head);
  printf("********************************************\n");
  printf("\n如需要其他服務,請重新輸入:");
  scanf("%d",&n);
  getchar();}break;//刪除聯絡人(讀入檔案,刪除連結串列、寫入檔案、釋放連結串列)
 case 6:{
  head=load_list(head);
      paixu_list(head);
  shifang_list(head);
  printf("********************************************\n");
  printf("\n如需要其他服務,請重新輸入:");
  scanf("%d",&n);
  getchar();}break;//檢視電話簿(讀入檔案,排序連結串列、釋放連結串列)
 case 7:{
  system("cls");
  return;}break;//退出
 default:{
  printf("\n輸入有誤,請重新輸入:");
  scanf("%d",&n);
  getchar();}break;
 }}
}

更多學習資料請關注專題《管理系統開發》。

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