当前位置: 首页 > news >正文

通讯录(静态版)

1.思路

​​

 2.代码

(1).contact.h

#pragma once#include<string.h>
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>#define MAX 100
#define MAX_NAME 20
#define MAX_SEX 10
#define MAX_TELE 12
#define MAX_ADDR 30//类型的声明
// 
//人的信息
typedef struct PeoInfo
{char name[MAX_NAME];int age;char sex[MAX_SEX];char tele[MAX_TELE];char addr[MAX_ADDR];
}PeoInfo;//通讯录typedef struct Contact
{PeoInfo data[MAX];//存放人的信息int count;//记录当前通讯录中实际人的个数
}Contact;//初始化通讯录
void InitContact(Contact* pc);//增加联系人的通讯录
void AddContact(Contact* pc);//打印通讯中的信息
void ShowContact(const Contact* pc);//删除指定联系人
void DelContact(Contact* pc);//查找指定联系人
void SearchContact(Contact* pc);//修改指定联系人
void ModifyContact(Contact* pc);//排序通讯录中内容
//按照名字来排序
//按照年龄来排序
//...
void SortContact(Contact* pc);

(2).contact.c

#include"contact.h"void InitContact(Contact* pc)
{assert(pc);pc->count = 0;memset(pc->data, 0, sizeof(pc->data));
}void AddContact(Contact* pc)
{assert(pc);if (pc->count == MAX){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);int i = 0;printf("%-20s\t%-5s\t%-5s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");for (i = 0; i < pc->count; i++){printf("%-20s\t%-5d\t%-5s\t%-12s\t%-30s\n", pc->data[i].name, pc->data[i].age, pc->data[i].sex,pc->data[i].tele, pc->data[i].addr);}
}static int FindByName(Contact* pc,char name[])
{assert(pc);int i = 0;for (i = 0; i < pc->count; i++){if (0 == strcmp(pc->data[i].name, name)){return i;}}return -1;
}void DelContact(Contact* pc)
{char name[MAX_NAME] = { 0 };assert(pc);int i = 0;if (pc->count == 0){printf("通讯录为空,没有信息可以删除\n");return;}printf("请输入要删除人的名字:");scanf("%s", name);//删除//1.查找int pos=FindByName(pc, name);if (pos == -1){printf("要删除的人不存在\n");return;}//2.删除for (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[MAX_NAME] = { 0 };printf("请输入要查找人的名字:");scanf("%s", name);//1.查找int pos = FindByName(pc, name);if (pos == -1){printf("要查找的人不存在\n");return;}//2.打印printf("%-20s\t%-5s\t%-5s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");printf("%-20s\t%-5d\t%-5s\t%-12s\t%-30s\n", pc->data[pos].name,pc->data[pos].age,pc->data[pos].sex,pc->data[pos].tele,pc->data[pos].addr);
}void ModifyContact(Contact* pc)
{assert(pc);char name[MAX_NAME] = { 0 };printf("请输入要修改人的名字:");scanf("%s", name);//1.查找int pos = FindByName(pc, name);if (pos == -1){printf("要修改的人不存在\n");return;}printf("要修改的人的信息已经查找到,接下来开始修改\n");//2.修改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");
}int cmp_peo_by_name(const void* e1, const void* e2)
{return strcmp(((PeoInfo*)e1)->name, ((PeoInfo*)e2)->name);
}
//按照名字来排序
void SortContact(Contact* pc)
{assert(pc);qsort(pc->data,pc->count,sizeof(PeoInfo), cmp_peo_by_name);printf("排序成功\n");
}

(3).test.c

#include"contact.h"
//1.静态版
void menu()
{printf("**********************************\n");printf("******  1.add     2.del    *******\n");printf("******  3.search  4.modify *******\n");printf("******  5.show    6.sort   *******\n");printf("******  0.exit             *******\n");printf("**********************************\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:SearchContact(&con);break;case 4:ModifyContact(&con);break;case 5:ShowContact(&con);break;case 6:SortContact(&con);break;case 0:printf("退出通讯录\n");break;default:printf("输入有误!\n");}} while (input);return 0;
}

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • GitLab CI Runner安装
  • 活动系统开发之采用设计模式与非设计模式的区别-非设计模式
  • [mysql]SQL语言的规则和规范
  • 黑链、黑帽、明链分别是什么意思
  • 通话记录被删除,如果快速恢复iPhone手机通话记录
  • 网络药理学:分子动力学模拟入门、gromacs能量最小化
  • 【原理图PCB专题】案例:Cadence能设计一个没有管脚的器件吗?
  • 云曦2024秋季开学考
  • 嵌入式产品发货后出现问题,怎么办?
  • 【Unity面经】性能优化篇
  • 掌握数据库与SQL
  • Mysql基础练习题 1729.求关注者的数量 (力扣)
  • 统计上升四元组
  • The component ‘GridItem‘ can only have a single child component.
  • 基于YOLOv8的风力涡轮机表面损坏检测系统
  • 4. 路由到控制器 - Laravel从零开始教程
  • Github访问慢解决办法
  • Git初体验
  • Hibernate【inverse和cascade属性】知识要点
  • Java 实战开发之spring、logback配置及chrome开发神器(六)
  • React系列之 Redux 架构模式
  • ViewService——一种保证客户端与服务端同步的方法
  • 工作中总结前端开发流程--vue项目
  • 规范化安全开发 KOA 手脚架
  • 解析 Webpack中import、require、按需加载的执行过程
  • 聚簇索引和非聚簇索引
  • 我建了一个叫Hello World的项目
  • 译米田引理
  • 最简单的无缝轮播
  • d²y/dx²; 偏导数问题 请问f1 f2是什么意思
  • ​ 轻量应用服务器:亚马逊云科技打造全球领先的云计算解决方案
  • %3cscript放入php,跟bWAPP学WEB安全(PHP代码)--XSS跨站脚本攻击
  • (1)(1.13) SiK无线电高级配置(五)
  • (day 2)JavaScript学习笔记(基础之变量、常量和注释)
  • (MonoGame从入门到放弃-1) MonoGame环境搭建
  • (差分)胡桃爱原石
  • (二)Kafka离线安装 - Zookeeper下载及安装
  • (附源码)基于SSM多源异构数据关联技术构建智能校园-计算机毕设 64366
  • (回溯) LeetCode 78. 子集
  • (接口封装)
  • (十八)三元表达式和列表解析
  • (十六)Flask之蓝图
  • (一)springboot2.7.6集成activit5.23.0之集成引擎
  • (已解决)vue+element-ui实现个人中心,仿照原神
  • (原+转)Ubuntu16.04软件中心闪退及wifi消失
  • *1 计算机基础和操作系统基础及几大协议
  • ... fatal error LINK1120:1个无法解析的外部命令 的解决办法
  • .cfg\.dat\.mak(持续补充)
  • .gitignore文件使用
  • .net 开发怎么实现前后端分离_前后端分离:分离式开发和一体式发布
  • .NET+WPF 桌面快速启动工具 GeekDesk
  • .net遍历html中全部的中文,ASP.NET中遍历页面的所有button控件
  • .NET面试题(二)
  • @Validated和@Valid校验参数区别
  • [120_移动开发Android]008_android开发之Pull操作xml文件