C语言实现通讯管理系统设计
作者:想飞的孤独少年 时间:2022-12-29 13:04:50
本文实例为大家分享了C语言实现通讯管理系统的具体代码,供大家参考,具体内容如下
#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("请输入编号,姓名,性别,电话和地址 \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("编号 姓名 性别 电话 地址 \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("没查到要查询的通讯者!\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 再 见!\n");
return 0;
}
}
}
int menu_select(){
int sn;
printf(" 通讯录管理系统\n");
printf("========================\n");
printf(" 1. 通讯录链表的建立\n");
printf(" 2. 通讯录信息的插入\n");
printf(" 3. 通讯录信息的查询\n");
printf(" 4. 通讯录信息的修改\n");
printf(" 5. 通讯录信息的删除\n");
printf(" 6. 通讯录信息的输出\n");
printf(" 0. 退出管理系统\n");
printf(" 请 选 择 0—6:");
for(; ;){
scanf("%d",&sn);
if(sn<0 || sn>6)
printf("\n\t输入错误,重选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("请顺序输入编号,姓名,性别,电话和地址\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("继续输入吗? (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. 按编号查询 \n");
printf("2. 按姓名查询 \n");
printf("===========\n");
printf(" 请选择:");
p=head->next;
scanf("%d",&xz);
if(xz==1){
printf("请输入要查询者的编号:");
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("请输入要查询者的姓名:");
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("没有查到要删除的通讯者!\n");
return;
}
printf("真的要删除该节点吗?(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("通讯录已经删除!\n");
}
}
void printList(LinkList head){
ListNode *p;
p=head->next;
printf("编号 姓名 性别 电话 地址\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("编号 姓名 性别 电话 地址\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("输入该通讯录者正确的联系电话 通讯地址:\n中间用空格号分隔\n");
scanf("%s%s",p->data.phone,p->data.addr);
}
else
printf("没查到要查询的通讯录者!\n");
}
更多学习资料请关注专题《管理系统开发》。
来源:http://blog.csdn.net/qq_33735635/article/details/73743400
标签:C语言,通讯,管理系统
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Android实现自动提取短信验证码功能
2022-11-19 23:58:49
![](https://img.aspxhome.com/file/2023/1/106811_0s.jpg)
c# wpf使用GMap.NET类库,实现地图轨迹回放
2023-04-20 06:46:27
![](https://img.aspxhome.com/file/2023/8/88418_0s.gif)
C#之IP地址和整数互转的小例子
2023-11-21 05:49:19
Android自定义View软键盘实现搜索
2022-02-10 07:22:45
c#装箱和拆箱知识整理
2023-03-14 00:42:02
java实现哈弗曼编码与反编码实例分享(哈弗曼算法)
2023-11-25 04:54:05
实例讲解Android多线程应用开发中Handler的使用
2021-11-23 03:23:13
![](https://img.aspxhome.com/file/2023/3/113293_0s.jpg)
Android实现自动变换大小的ViewPager
2023-03-19 06:56:15
![](https://img.aspxhome.com/file/2023/0/94260_0s.gif)
Android利用LitePal操作数据库存取图片
2021-06-14 14:57:45
Java实现经典游戏复杂迷宫
2021-05-29 22:33:34
![](https://img.aspxhome.com/file/2023/1/63301_0s.png)
使用SpringBoot配置多数据源的经验分享
2022-05-25 04:02:57
![](https://img.aspxhome.com/file/2023/1/97931_0s.png)
浅谈java封装
2023-05-05 22:48:20
C#中一些你可能没用过的调试窗口的方法
2022-08-07 09:01:16
![](https://img.aspxhome.com/file/2023/8/96368_0s.png)
java简单实现数组中的逆序对
2022-06-26 02:23:17
浅试仿 mapstruct实现微服务编排框架详解
2022-07-12 13:20:44
![](https://img.aspxhome.com/file/2023/0/63420_0s.png)
Java 守护线程_动力节点Java学院整理
2023-11-28 07:51:14
![](https://img.aspxhome.com/file/2023/7/60177_0s.png)
Java 遍历取出Map集合key-value数据的4种方法
2022-02-03 02:48:59
![](https://img.aspxhome.com/file/2023/0/71640_0s.png)
详解java中接口与抽象类的区别
2021-09-12 03:21:39
Java的接口调用时的权限验证功能的实现
2023-08-09 11:15:06
![](https://img.aspxhome.com/file/2023/0/70560_0s.png)
c#多线程之线程基础
2022-10-06 20:34:44