C語(yǔ)言實(shí)現(xiàn)通訊管理系統(tǒng)設(shè)計(jì)
更新時(shí)間:2018年01月15日 11:28:57 作者:想飛的孤獨(dú)少年
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)通訊管理系統(tǒng)設(shè)計(jì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本文實(shí)例為大家分享了C語(yǔ)言實(shí)現(xiàn)通訊管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct{
char num[5];
char name[9];
char sex[9];
char phone[13];
char addr[31];
}DataType;
typedef struct node{
DataType data;
struct node*next;
} ListNode, *LinkList;
LinkList head;
ListNode *p;
int menu_select();
LinkList CreateList(void);
void InsertNode(LinkList head,ListNode *p);
ListNode *ListFind(LinkList head);
void DelNode(LinkList head);
void printList(LinkList head);
void ChangeNode(LinkList head);
int main(void){
for(; ;){
switch(menu_select()){
case 1:
printf("**********************\n");
printf("* 通 訊 錄 鏈 表 建 立 *\n");
printf("***********************\n");
head=CreateList();
break;
case 2:
printf("*********************\n");
printf("通 訊 錄 信 息 的 插 入 *\n");
printf("*********************\n");
printf("請(qǐng)輸入編號(hào),姓名,性別,電話和地址 \n");
printf("**********************************\n");
p=(ListNode*)malloc(sizeof(ListNode));
scanf("%s%s%s%s%s",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr);
InsertNode(head,p);
break;
case 3:
printf("***********************\n");
printf("通 訊 錄 的 查 詢 *\n");
p=ListFind(head);
if(p!=NULL){
printf("編號(hào) 姓名 性別 電話 地址 \n");
printf("-------------------------- \n");
printf("%s%s%s%s%s",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr);
} else
printf("沒(méi)查到要查詢的通訊者!\n");
break;
case 4:
printf("***********************\n");
printf("* 通 訊 者 信 息 的 修 改 *\n");
printf("**********************\n");
ChangeNode(head);
break;
case 5:
printf("************************\n");
printf("通 訊 錄 的 信 息 刪 除 *\n");
printf("*************************\n");
DelNode(head);
break;
case 6:
printf("************************\n");
printf("通 訊 錄 鏈 表 的 輸 出 *\n");
printf("*************************\n");
printList(head);
break;
case 0:
printf("\t 再 見(jiàn)!\n");
return 0;
}
}
}
int menu_select(){
int sn;
printf(" 通訊錄管理系統(tǒng)\n");
printf("========================\n");
printf(" 1. 通訊錄鏈表的建立\n");
printf(" 2. 通訊錄信息的插入\n");
printf(" 3. 通訊錄信息的查詢\n");
printf(" 4. 通訊錄信息的修改\n");
printf(" 5. 通訊錄信息的刪除\n");
printf(" 6. 通訊錄信息的輸出\n");
printf(" 0. 退出管理系統(tǒng)\n");
printf(" 請(qǐng) 選 擇 0—6:");
for(; ;){
scanf("%d",&sn);
if(sn<0 || sn>6)
printf("\n\t輸入錯(cuò)誤,重選0-6:");
else
break;
}
return sn;
}
LinkList CreateList(void){
LinkList head=(ListNode *)malloc(sizeof(ListNode));
ListNode *p,*rear;
char flag='y';
rear=head;
while(flag=='y'){
p=(ListNode *)malloc(sizeof(ListNode));
printf("請(qǐng)順序輸入編號(hào),姓名,性別,電話和地址\n");
printf("--------------------------------------\n");
scanf("%s%s%s%s%s",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr);
rear->next=p;
rear=p;
printf("繼續(xù)輸入嗎? (y/n):");
getchar();
scanf("%c",&flag);
}
rear->next=NULL;
return head;
}
void InsertNode(LinkList head,ListNode *p){
ListNode *p1,*p2;
p1=head;
p2=p1->next;
while(p2!=NULL && strcmp(p2->data.num,p->data.num)<0)
{
p1=p2;
p2=p2->next;
}
p1->next=p;
p->next=p2;
}
ListNode *ListFind(LinkList head){
ListNode *p;
char num[5];
char name[9];
int xz=0;
printf("===========\n");
printf("1. 按編號(hào)查詢 \n");
printf("2. 按姓名查詢 \n");
printf("===========\n");
printf(" 請(qǐng)選擇:");
p=head->next;
scanf("%d",&xz);
if(xz==1){
printf("請(qǐng)輸入要查詢者的編號(hào):");
scanf("%s",num);
while(p && strcmp(p->data.num,num)<0)
p=p->next;
if(p==NULL||strcmp(p->data.num,num)>0)
p=NULL;
}
else
if(xz==2) {
printf("請(qǐng)輸入要查詢者的姓名:");
scanf("%s",name);
while(p && strcmp(p->data.name,name)!=0)
p=p->next;
}
return p;
}
void DelNode(LinkList head){
char jx;
ListNode *p,*q;
p=ListFind(head);
if(p==NULL){
printf("沒(méi)有查到要?jiǎng)h除的通訊者!\n");
return;
}
printf("真的要?jiǎng)h除該節(jié)點(diǎn)嗎?(y/n):");
getchar();
scanf("%c",&jx);
if(jx=='y'||jx=='Y'){
q=head;
while(q!=NULL && q->next!=p)
q=q->next;
q->next=p->next;
free(p);
printf("通訊錄已經(jīng)刪除!\n");
}
}
void printList(LinkList head){
ListNode *p;
p=head->next;
printf("編號(hào) 姓名 性別 電話 地址\n");
printf("--------------------------------------\n");
while(p!=NULL)
{
printf("%s%s%s%s%s\n",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr);
printf("--------------------------------\n");
p=p->next;
}
}
void ChangeNode(LinkList head){
ListNode *p;
p=ListFind(head);
if(p!=NULL){
printf("編號(hào) 姓名 性別 電話 地址\n");
printf("--------------------------------------\n");
scanf("%s%s%s%s%s\n",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr);
printf("--------------------------------------\n");
printf("輸入該通訊錄者正確的聯(lián)系電話 通訊地址:\n中間用空格號(hào)分隔\n");
scanf("%s%s",p->data.phone,p->data.addr);
}
else
printf("沒(méi)查到要查詢的通訊錄者!\n");
}
更多學(xué)習(xí)資料請(qǐng)關(guān)注專題《管理系統(tǒng)開(kāi)發(fā)》。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生學(xué)籍管理系統(tǒng)
- 學(xué)生信息管理系統(tǒng)C語(yǔ)言版
- C語(yǔ)言單鏈表版學(xué)生信息管理系統(tǒng)
- C語(yǔ)言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(單鏈表)
- C語(yǔ)言學(xué)生信息管理系統(tǒng)小項(xiàng)目
- C語(yǔ)言數(shù)組實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)設(shè)計(jì)
- C語(yǔ)言版學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言學(xué)生信息管理系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)
- 基于C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言學(xué)生學(xué)籍管理系統(tǒng)課程設(shè)計(jì)
相關(guān)文章
詳解設(shè)計(jì)模式中的模板方法模式及在C++中的使用
這篇文章主要介紹了設(shè)計(jì)模式中的模板方法模式及在C++中的使用,模板方法將邏輯封裝到一個(gè)類中,并采取組合(委托)的方式解決這個(gè)問(wèn)題,需要的朋友可以參考下2016-03-03
C++實(shí)現(xiàn)Dijkstra算法的示例代碼
迪杰斯特拉算法(Dijkstra)是由荷蘭計(jì)算機(jī)科學(xué)家狄克斯特拉于1959年提出的,因此又叫狄克斯特拉算法。是從一個(gè)頂點(diǎn)到其余各頂點(diǎn)的最短路徑算法。本文將用C++實(shí)現(xiàn)Dijkstra算法,需要的可以參考一下2022-07-07
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之動(dòng)態(tài)分配實(shí)現(xiàn)串
這篇文章主要介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之動(dòng)態(tài)分配實(shí)現(xiàn)串的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家實(shí)現(xiàn)數(shù)據(jù)結(jié)構(gòu)中動(dòng)態(tài)分配實(shí)現(xiàn)串的實(shí)例,需要的朋友可以參考下2017-10-10

