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语言,通讯,管理系统
0
投稿

猜你喜欢

  • Android实现自动提取短信验证码功能

    2022-11-19 23:58:49
  • c# wpf使用GMap.NET类库,实现地图轨迹回放

    2023-04-20 06:46:27
  • 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
  • Android实现自动变换大小的ViewPager

    2023-03-19 06:56:15
  • Android利用LitePal操作数据库存取图片

    2021-06-14 14:57:45
  • Java实现经典游戏复杂迷宫

    2021-05-29 22:33:34
  • 使用SpringBoot配置多数据源的经验分享

    2022-05-25 04:02:57
  • 浅谈java封装

    2023-05-05 22:48:20
  • C#中一些你可能没用过的调试窗口的方法

    2022-08-07 09:01:16
  • java简单实现数组中的逆序对

    2022-06-26 02:23:17
  • 浅试仿 mapstruct实现微服务编排框架详解

    2022-07-12 13:20:44
  • Java 守护线程_动力节点Java学院整理

    2023-11-28 07:51:14
  • Java 遍历取出Map集合key-value数据的4种方法

    2022-02-03 02:48:59
  • 详解java中接口与抽象类的区别

    2021-09-12 03:21:39
  • Java的接口调用时的权限验证功能的实现

    2023-08-09 11:15:06
  • c#多线程之线程基础

    2022-10-06 20:34:44
  • asp之家 软件编程 m.aspxhome.com