C语言实现通讯管理系统设计
作者:想飞的孤独少年 发布时间:2022-12-29 13:04:50
标签:C语言,通讯,管理系统
本文实例为大家分享了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
![](https://www.aspxhome.com/images/zang.png)
![](https://www.aspxhome.com/images/jiucuo.png)
猜你喜欢
- 递归出现栈溢出stackoverflow递归是个不断回调方法的过程,使方法一遍遍的压入栈中,递归次数多了,栈满了也就溢出了。默认的栈大小是1
- 折半搜索,也称二分查找算法、二分搜索,是一种在有序数组中查找某一特定元素的搜索算法。A 搜素过程从数组的中间元素开始,如果中间元素正好是要查
- 用法一:常量在JDK1.5之前,我们定义常量都是:publicstaticfianl....。现在好了,有了枚举,可以把相关的常量分组到一个
- 1.导入System.Runtime.InteropServices命名空间。2.API函数ShowWindow()能够控制人和窗体的现实状
- Mybatis-Plus是一个优秀的Mybatis增强工具,目前更新到3.1.1。Mybatis-Plus原生提供了很多单表操作的方法,极大
- 朋友让我帮忙写个程序从文本文档中导入数据到oracle数据库中,技术上没有什么难度,文档的格式都是固定的只要对应数据库中的字段解析就行了,关
- Activiti项目是一项新的基于Apache许可的开源BPM平台,本文就来简述一下Activiti常用类。具体如下:一、为什么要使用工作流
- 一、int还记得 C 语言里的 int 吗,C里面的 int 有着无符号与有符号之分但是Java内就没有,且固定占4个字节大小,也就是32比
- 前言今天起床,拿起手机开机第一时间当然是打开微信了,左右滑动Viewpager,发现它使用了一种叫惰性加载,或者说懒加载(lazy-load
- 继续我们的源码解析,上一篇文章我们介绍了Activity的启动流程,一个典型的场景就是Activity a 启动了一个Activity b,
- 1.微信配置信息 global.properties2.方法wxpay用于生成预支付订单信息方法notifyWeiXinPay用于微信支付成
- MybatisPlus特性•无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑•损耗小:启动即会自动注入基本 CURD,性能
- 有时候我们需要多列表中的数据进行特定的排序,最近项目中用到的是按名称排序,所以简单来说一下:效果图:排序方法:Collections.sor
- Java中获取整点时间戳在实际的开发过程中,前端给后端传时间的时候,有时候传的是整点数值,比如:timeList=[00,01,02,03,
- JAVA用于开发图形界面应用的 SWING 组件包功能强大,使用方便。接下来我们就使用其写一个简单的图形界面小程序:加法计算器。第一步:首先
- 最近有个粉丝提了个问题,说他在Spring Security中用JWT做退出登录的时无法获取当前用户,导致无法证明“我就是要退出的那个我”,
- Spring Boot 异常处理异常处理是一种识别并响应错误的一致性机制,异常机制可以把程序中的异常处理代码和正常的业务逻辑代码分离,包装程
- Mybatis条件if test使用枚举值1.正确package com.weather.weatherexpert.common.util
- 前言本文介绍在spring mvc中非常重要的注解@ModelAttribute.这个注解可以用在方法参数上,或是方法声明上。这个注解的主要
- 我们在平常项目开发中,经常会用到周期性定时任务,这个时候使用定时任务就能很方便的实现。在SpringBoot中用得最多的就是Schedule