用c语言实现静态通讯录

思路:

将代码分成三个模块,头文件contact.h:声明函数,定义结构体

                                    test.c测试类,contact.c用来实现通讯录中的函数功能

1.打印菜单,让用户进行选择

2.定义一个结构体PeoInfo,其中包含联系人的信息,如姓名等。将PeoInfo定义一个100大小的数组data,与count封装再同一结构体Contact中,可以这个count来记录data数组的增删查改,因为初始化为0后可以作为数组data的下标

3.用Contact创建一个con成员,并初始化。但结构体数组,要想全部成员都进行初始化,需要用到

void * memset ( void * ptr, int value, size_t num ) 函数。

4.功能实现:添加成员后count++,删除成员后count--,访问成员时则以下循环就行for i in range(0,pc->count),当然,查找,删除,修改都需要用到查找函数。排序可以用库函数qsort来实现。

5.代码如下:

头文件:contact.h

#pragma once#include <stdio.h>
#include <string.h>
#include <assert.h>
#include <stdlib.h>#define MAX_CONTACTS 100//定义联系人
typedef struct PenInfo {char name[20];int age;char sex[10];char tele[12];char addr[30];
}PenInfo;//通讯录所包含内容
typedef struct Contact {PenInfo data[MAX_CONTACTS];int count;
}Contact;//初始化联系人列表
void Initcontact(Contact *pc);//添加联系人
void Addcontact(Contact *pc);//删除练习人
void Delcontact(Contact* pc);//显示联系人
void Showcontact(const Contact* pc); //查找联系人
void Searchcontact(Contact* pc);//修改联系人
void Modifycontact(Contact* pc);//排序
void Sortcontact(Contact* pc);

 contact.c:

#define _CRT_SECURE_NO_WARNINGS#include "contact.h"void Initcontact(Contact* pc) {memset(pc->data, 0, sizeof(pc->data));pc->count = 0;
}void Addcontact(Contact* pc){assert(pc);if (pc->count == 100) {printf("联系人已满,无法添加\n");return;}printf("请输入联系人名字:>");scanf("%s", pc->data[pc->count].name);printf("请输入联系人年龄:>");scanf("%d", &(pc->data[pc->count].age));printf("请输入联系人性别:>");scanf("%s", pc->data[pc->count].sex);printf("请输入联系人电话:>");scanf("%s", pc->data[pc->count].tele);printf("请输入联系人地址:>");scanf("%s", pc->data[pc->count].addr);pc->count++;printf("添加成功\n");
}void Showcontact(const Contact* pc) {assert(pc);if (pc->count == 0) {printf("还没添加联系人\n");return;}printf("%-20s\t%-3s\t%-10s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");printf("-----------------------------------------------------------------------------\n");for (int i = 0; i < pc->count; i++) {printf("%-20s\t%-5d\t%-10s\t%-12s\t%-30s", pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);printf("\n");printf("-----------------------------------------------------------------------------\n");}
}//查找联系人
static int Findcontact(Contact* pc, char* name) {assert(pc);for (int i = 0; i < pc->count; i++) {if (strcmp(name, pc->data[i].name) == 0) {return i;}}return -1;
}
void Delcontact(Contact* pc) {assert(pc);char name[20] = { 0 };printf("请输入要删除的联系人名字:>");scanf("%s", name);//查找int pos = Findcontact(pc, name);//删除if (pos == -1) {printf("没有该联系人\n");return;}for (int i = pos; i < pc->count + 1; i++) {pc->data[i] = pc->data[i + 1];}pc->count--;printf("删除成功\n");}void Searchcontact(Contact* pc) {assert(pc);char name[20] = { 0 };printf("请输入要查找的联系人名字:>");scanf("%s", name);//查找int pos = Findcontact(pc, name);//删除if (pos == -1) {printf("没有该联系人\n");return;}else {printf("找到了\n");printf("%-20s\t%-3s\t%-10s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");printf("-----------------------------------------------------------------------------\n");printf("%-20s\t%-5d\t%-10s\t%-12s\t%-30s", pc->data[pos].name,pc->data[pos].age,pc->data[pos].sex,pc->data[pos].tele,pc->data[pos].addr);printf("\n");printf("-----------------------------------------------------------------------------\n");}}void Modifycontact(Contact* pc) {assert(pc);char name[20] = { 0 };printf("请输入要修改的联系人的名字:>");scanf("%s", name);//查找int pos = Findcontact(pc, name);//删除if (pos == -1) {printf("没有该联系人\n");return;}else {printf("修改后联系人名字:>");scanf("%s", pc->data[pos].name);printf("修改后联系人年龄:>");scanf("%d", &(pc->data[pos].age));printf("修改后联系人性别:>");scanf("%s", pc->data[pos].sex);printf("修改后联系人电话:>");scanf("%s", pc->data[pos].tele);printf("修改后联系人地址:>");scanf("%s", pc->data[pos].addr);printf("\n");printf("修改成功\n");}
}//按姓名排序函数
int Sort_by_name(const void* e1, const void* e2) {return strcmp(((PenInfo*)e1)->name, ((PenInfo*)e2)->name);
}
//按年龄排序
int Sort_by_age(const void* e1, const void* e2) {if (((PenInfo*)e1)->age< ((PenInfo*)e2)->age){return -1;}if (((PenInfo*)e1)->age > ((PenInfo*)e2)->age) {return 1;}if (((PenInfo*)e1)->age == ((PenInfo*)e2)->age) {return 0;}
}
void Sortcontact(Contact* pc) {assert(pc);int chiose;printf("(1.按姓名排序 2.按年龄排序):>");scanf("%d", &chiose);if (chiose == 1) {qsort(pc->data,pc->count,sizeof(PenInfo), Sort_by_name);printf("排序成功\n");}else if (chiose == 2) {qsort(pc->data, pc->count, sizeof(PenInfo), Sort_by_age);printf("排序成功\n");}else {printf("无效输入\n");return;}
}

test.c:

#define _CRT_SECURE_NO_WARNINGS#include "contact.h"//创建菜单
void menu() {printf("------------My ContactBook------------\n");printf("-----------1.Add linkman  ------------\n");printf("-----------2.Del linkman  ------------\n");printf("-----------3.Show linkman ------------\n");printf("-----------4.Search linkman ----------\n");printf("-----------5.Modify linkman ----------\n");printf("-----------6.Sort linkman -----------\n");printf("-----------0.Exit menu  -------------\n");}
int main() {    int input = 0;//创建联系人Contact con;Initcontact(&con);do {menu();printf("请选择对应功能的编号:>");scanf("%d", &input);switch (input) {case 1:         Addcontact(&con);break;case 2:Delcontact(&con);break;case 3:Showcontact(&con);break;case 4:Searchcontact(&con);break;case 5:Modifycontact(&con);break;case 6:Sortcontact(&con);break;case 0:printf("退出成功\n");break;default :printf("选择错误\n");break;}} while (input);return 0;
}

这是一个静态版本,还有许多功能尚未完善,等待后续开发。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/99440.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OCR让点读笔如虎添翼

点读笔是一种智能学习工具&#xff0c;它可以通过识别文字来提供相应的语音或图像反馈。在实现文字识别功能时&#xff0c;点读笔通常会借助OCR&#xff08;Optical Character Recognition&#xff0c;光学字符识别&#xff09;技术。下面将详细介绍点读笔如何利用OCR技术实现文…

【Spring Cloud系统】- Zookeer特性与使用场景

【Spring Cloud系统】- Zookeer特性与使用场景 一、概述 Zookeeper是一个分布式服务框架&#xff0c;是Apache Hadoop的一个子项目&#xff0c;它主要是用来解决分布式应用中经常遇到的一些数据管理问题。如&#xff1a;统一命名服务、状态同步服务、集群管理、分布式应用配置…

Python的logging模块Demo

Tip&#xff1a;默认情况下&#xff0c;logging模块不会自动地将日志存储到某个特定路径&#xff0c;除非你指定了该路径。你需要创建一个FileHandler&#xff0c;然后为其设置一个文件路径&#xff0c;这样日志就会被写入到该文件中。 以下是一个简单的例子&#xff0c;展示如…

Android开发入门技能(Java)

Android开发入门技能 一些流行的框架和库 安卓开发中有许多主流框架和库&#xff0c;它们可以帮助开发者更轻松地构建功能强大、高效和可维护的应用程序。以下是一些主要的安卓开发框架和库&#xff1a; Android Jetpack&#xff1a;Android Jetpack是官方提供的一套库和工具…

基于AlexNet深度学习网络的智能垃圾分类系统matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1、基于AlexNet深度学习网络的智能垃圾分类系统概述 4.2、基于AlexNet深度学习网络的智能垃圾分类系统主要原理 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab20…

【CSS】Tailwind CSS

直接参考 Tailwind CSS 安装提供了四种方式。因为我常用构建工具搭建项目&#xff0c;所以选择 Using PostCSS 。 其中 tailwind.config.js 的配置可以改为&#xff1a; module.exports {content: [./index.html, ./src/**/*.{vue,js,ts,jsx,tsx}],theme: {extend: {},},pl…

在宝塔面板环境下安装nps服务端

在宝塔面板环境下安装nps服务端 一、所需环境二、开始安装三、打开nps控制台四、更改默认账号密码和连接秘钥五、反向代理挂载SSL证书 一、所需环境 阿里云轻应用服务器&#xff08;选择宝塔应用镜像&#xff09;域名&#xff08;最好也是阿里注册的域名&#xff09;对应的ssl…

echarts的bug,在series里写tooltip,不起作用,要在全局先写tooltip:{}才起作用,如果在series里写的不起作用就写到全局里

echarts的bug&#xff0c;在series里写tooltip&#xff0c;不起作用&#xff0c;要在全局先写tooltip&#xff1a;{show:true}才起作用&#xff0c;如果在series里写的不起作用就写到全局里 series里写tooltip不起作用&#xff0c;鼠标悬浮在echarts图表上时不显示提示 你需要…

聊聊分布式架构01——http通信基础

目录 web通信的简单结构 网络通信基础TCP/IP TCP/IP 通信传输流 HTTP中的三剑客 负责传输的IP协议 确保可靠性的TCP协议 SYN攻击&#xff08;SYN Flood Attack&#xff09; 四次挥手 负责域名解析的DNS服务 基于 TCP 协议实现通信 TCP 协议的通信过程 Web通信的简单…

LinkedBlockingQueue:Java并发编程的强大工具

LinkedBlockingQueue&#xff1a;Java并发编程的强大工具 在Java并发编程中&#xff0c;LinkedBlockingQueue是一个非常重要的数据结构&#xff0c;它是一个线程安全的队列&#xff0c;能够有效地管理和控制多线程环境中的任务。本文将介绍LinkedBlockingQueue的工作原理、应用…

基于PSD-ML算法的语音增强算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 1.加窗处理&#xff1a; 2.分帧处理&#xff1a; 3.功率谱密度估计&#xff1a; 4.滤波处理&#xff1a; 5.逆变换处理&#xff1a; 6.合并处理&#xff1a; 5.算法完整程序工程 1.算法…

visual studio解决bug封装dll库

1.速度最大化 O2 2.设置输出目录 配置属性/常规/输出目录 链接器/常规/输出dll文件 链接器/调试/输出程序数据库pdb文件 链接器/高级/导入库 3.输出X86 X64分别对应的dll、lib、pdb 然后修改更新说明 更新说明格式如下&#xff1a; 4.将库提交到FTP每日更新库文档下 和测试交接…

docker入门加实战—docker安装并配置阿里云加速

docker入门加实战—docker安装并配置阿里云加速 为什么要学习docker 在开发和部署项目的过程中&#xff0c;经常会遇到如下问题&#xff1a; 软件安装包名字复杂&#xff0c;不知道去哪里找安装软件和部署项目步骤复杂&#xff0c;容易出错 这就是我们今天要学习Docker技术…

idea如何拷贝maven中所引用的所有jar

要拷贝 Maven 中引用的所有 JAR 文件&#xff0c;可以使用 Maven 提供的命令行工具和插件。以下是一些步骤供您参考&#xff1a; 确保已经在本地安装了 Maven。 在命令行中进入包含 Maven 项目的根目录。 运行以下命令&#xff0c;将项目构建到本地仓库&#xff1a; mvn clea…

千兆以太网传输层 UDP 协议原理与 FPGA 实现(UDP接收)

文章目录 前言心得体会一、 UDP 协议简单回顾二、UDP接收实现三、完整代码展示四、仿真测试(1)模拟电脑数据发送,(2)测试顶层文件编写(3)仿真文件(4)仿真波形前言 在前面我们对以太网 UDP 帧格式做了讲解,UDP 帧格式包括前导码+帧界定符、以太网头部数据、IP 头部数…

vue3的element-plus的el-dialog的样式修改无效问题

问题描述 想要修改element-plus的对话框el-dialog中的样式&#xff0c;发现在页面style的scoped属性下&#xff0c;使用:deep深入选择器进行修改是无效的。&#xff08;vue2下深度选择器是有效的&#xff09; //无效 :deep(.el-dialog){background-color: transparent; }解决…

跨平台应用开发比较,QT还是Electron

开发技术比较 在技术选择中&#xff0c;我们选中了两个技术路线&#xff0c;一个是基于C的QT&#xff0c;一个是基于nodejs的electron&#xff0c;我们仔细比价了两个产品的优缺点。 electronQT开发简单&#xff0c;上手快速上手慢&#xff0c;但是性能高适用于一些单一功能的…

解释器模式 行为型模式之五

1.定义 给定一个语言&#xff0c;定义它的文法的一种表示&#xff0c;并定义一个解释器。比如加减乘除在代码里是一种表示&#xff0c;我们需要翻译成可以阅读的数学公式&#xff0c;并且可以供用户输入数字得到输出结果。 2.组成结构 抽象表达式&#xff08;Abstract Expres…

比较react和vue的响应式原理

React 和 Vue 都使用虚拟 DOM 来提高性能&#xff0c;但在响应式原理和状态管理方面有一些不同。React 更注重单向数据流和手动状态管理&#xff0c;而 Vue 强调响应式数据绑定和自动状态追踪&#xff0c;使开发更加便捷。 React的响应式原理&#xff1a; 虚拟 DOM和单向数据流…

第二证券:临时停牌一般多久?

随着股票买卖市场的日益开展&#xff0c;股票买卖的监管也越来越严格。而前段时刻&#xff0c;上市公司中多家公司被暂时停牌&#xff0c;此举引起了公众对于暂时停牌时刻的重视。那么&#xff0c;暂时停牌一般多久&#xff1f;本篇文章将从多个视点出发&#xff0c;对这一问题…