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

宁晋网站建设地址信息采集平台

宁晋网站建设,地址信息采集平台,wordpress果酱二维码,深圳百度搜索排名优化目录 一、关于通讯录 二、代码逻辑 三、通讯录实现 1.菜单设计 2.逻辑主要功能设计 3.增加联系人功能实现 4.显示全部联系人信息 5.删除联系人 6.查找联系人 7.修改联系人信息 8.对联系人进行排序 9.一键清空所有联系人 四、完整源码 test.c contact.c contact.…

目录

一、关于通讯录

二、代码逻辑

三、通讯录实现

1.菜单设计

2.逻辑主要功能设计

3.增加联系人功能实现

4.显示全部联系人信息 

 5.删除联系人

6.查找联系人

7.修改联系人信息

8.对联系人进行排序

 9.一键清空所有联系人

四、完整源码

test.c

contact.c

contact.h


一、关于通讯录

在通讯录中,我们一般保存联系人的信息,联系人的信息一般会有 姓名、年龄、性别、电话、地址等。在通讯录中,我们也会对一些信息进行增删改查。

二、代码逻辑

代码文件

test.c 用于测试代码

contact.h 用于存放头文件

contact.c 用于主要代码的功能实现

  1. 菜单设计
  2. 功能实现

三、通讯录实现

1.菜单设计

void menu() 
{printf("***********************************\n");printf("****** 1. add      2. del    ******\n");printf("****** 3. search   4. modify ******\n");printf("****** 5. show     6. sort   ******\n");printf("****** 7. clear    0. exit   ******\n");printf("***********************************\n");
}

 

2.逻辑主要功能设计

因为有了菜单可以进行功能选择

功能实现的前提是  先对通讯录 进行设计 并 初始化

采用结构体进行设计

typedef struct PeoInfo 
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tele[TELE_MAX];char addr[ADDR_MAX];
}PeoInfo;typedef struct Contact 
{PeoInfo data[MAX];//存放通讯录数据int sz;//记录通讯录存了多少个数据
}Contact;

 

通讯录初始化(使用memset 将通讯录数据置0)

//初始化通讯录
void InitContact(Contact *pc) 
{assert(pc);//断言一下,避免空指针//将通讯录数据置0memset(pc->data,0,sizeof(pc->data)); //这里使用的内存函数,也可以使用for循环进行pc->sz = 0;//将记录通讯录信息个数置0
}

采用do ...while 和 switch 进行设计

	do {menu();printf("请输入你的选择:>");scanf("%d",&input);switch (input) {case ADD:AddContact(&con);//增加联系人break;case DEL:DelContact(&con);//删除联系人break;case SEARCH:SearchContact(&con);//查找联系人break;case MODIFY:ModifyContact(&con);//修改联系人信息break;case SHOW:ShowContact(&con);//显示全部联系人break;case SORT:SortContact(&con);//对联系人进行排序break;case CLEAR:InitContact(&con);//清空通讯录break;case EXIT:printf("退出通讯录!\n");break;default:Sleep(300);system("cls");//清屏printf("输入错误,请重新输入!\n");}} while (input);

在这里我们发现switch 语句中 的case 选项中的常量表达式 是字母,这里主要是利用了枚举常量。

enum Option 
{EXIT,ADD,DEL,SEARCH,MODIFY,SHOW,SORT,CLEAR
};

EXIT表示0 ,ADD表示1 依次类推... 

这样在switch语句中就增加了代码的可读性和可调试性

3.增加联系人功能实现

//增加联系人
void AddContact(Contact* pc) 
{assert(pc);//首先应该判断通讯录是否已满if (pc->sz == MAX) {printf("通讯录已满,无法添加!\n");return;}Sleep(300);system("cls");//清屏//增加的信息//名字 年龄 性别 电话 地址printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n","名字","年龄","性别","电话","地址");printf("----------------------------------------------------------------------------\n");//增加信息printf("请输入名字:");scanf("%s",pc->data[pc->sz].name);printf("请输入年龄:");scanf("%d",&(pc->data[pc->sz].age));printf("请输入性别:");scanf("%s", pc->data[pc->sz].sex);printf("请输入电话:");scanf("%s", pc->data[pc->sz].tele);printf("请输入地址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("增加成功\n");Sleep(1000);system("cls");//清屏
}

4.显示全部联系人信息 

上述是增加联系人的信息,既然增加联系人我们就来查看联系人信息

//显示全部联系人
void ShowContact( const Contact* pc)
{assert(pc);if (pc->sz == 0){printf("通讯录为空!\n");Sleep(1000);system("cls");//清屏return;}printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc -> sz;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);}}

 

 5.删除联系人

这里采用的思想是 数组后面的元素前移将前面的元素覆盖来达到删除该信息的目的

这里是删除指定联系人

//按名字查找
static int FindByName(Contact* pc,char name[])
{assert(pc);int i = 0;for (i = 0; i < pc->sz;i++){if (strcmp(pc->data[i].name,name) == 0) {return i;}}return -1;
}//删除联系人
void DelContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法删除!\n");Sleep(1000);system("cls");//清屏return;}char name[NAME_MAX];printf("输入要删除的名字:");scanf("%s",&name);int ret = FindByName(pc,name);if (ret == -1){printf("要删除的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}int i = 0;//进行删除的操作for (i = ret; i < pc->sz - 1;i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");Sleep(1000);system("cls");//清屏
}

6.查找联系人

 

//查找联系人
void SearchContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];Sleep(1000);system("cls");//清屏printf("请输入要查找人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要查找的联系人不存在\n");//Sleep(1000);//system("cls");//清屏return;}Sleep(1000);system("cls");//清屏//显示出查找的联系人printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-18s\n",pc->data[ret].name,pc->data[ret].age,pc->data[ret].sex,pc->data[ret].tele,pc->data[ret].addr);Sleep(3000);
}

7.修改联系人信息

enum option_menu 
{EXIT,NAME ,AGE,SEX,TELE,ADDR
};
//修改联系人信息
void ModifyContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];printf("请输入要修改联系人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要修改的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}//修改联系人printf("**********\n");printf("#1. 名字 *\n#2. 年龄 *\n#3. 性别 *\n#4. 电话 *\n#5. 地址 *\n#0. 返回 *\n");printf("**********\n");int input = 0;do{//option_menu();printf("请选择你要的信息:>\n");scanf("%d", &input);switch (input){case NAME:printf("请输入名字:\n");scanf("%s", pc->data[ret].name);break;case AGE:printf("请输入年龄:\n");scanf("%d", &(pc->data[ret].age));break;case SEX:printf("请输入性别:\n");scanf("%s", pc->data[ret].sex);break;case TELE:printf("请输入电话:\n");scanf("%s", pc->data[ret].tele);break;case ADDR:printf("请输入地址:\n");scanf("%s", pc->data[ret].addr);break;case EXIT:printf("返回主界面\n");return;default:printf("输入错误,请重新输入\n");break;}} while (input);}

 

8.对联系人进行排序

int cmp_name(const void* s1,const void* s2) 
{return strcmp(((Contact*)s1)->data->name, ((Contact*)s2)->data->name);
}
int cmp_age(const void* s1,const void* s2)
{return ((Contact*)s1)->data->age - ((Contact*)s2)->data->age;
}
//排序
void SortContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法排序 !");return;}int input = 0;printf("***********\n");printf("# 1. 名字 *\n# 2. 年龄 *\n");printf("***********\n");printf("请选择排序的方法:");scanf("%d",&input);if (input == 1) {//按名字进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_name);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; 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);}}else if (input == 2) {//按年龄进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_age);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; 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);}}
}

 

先展示一下原来数据的信息

 排序1

排序2

 

 9.一键清空所有联系人

 这里是直接调用的初始化通讯录函数

//初始化通讯录
void InitContact(Contact *pc) 
{assert(pc);//断言一下,避免空指针//将通讯录数据置0memset(pc->data,0,sizeof(pc->data)); //这里使用的内存函数,也可以使用for循环进行pc->sz = 0;//将记录通讯录信息个数置0
}

四、完整源码

test.c

#define _CRT_SECURE_NO_WARNINGS 
//用于测试
#include "contact.h"
void menu() 
{printf("***********************************\n");printf("****** 1. add      2. del    ******\n");printf("****** 3. search   4. modify ******\n");printf("****** 5. show     6. sort   ******\n");printf("****** 7. clear    0. exit   ******\n");printf("***********************************\n");
}
enum Option 
{EXIT,ADD,DEL,SEARCH,MODIFY,SHOW,SORT,CLEAR
};
int main() 
{int input = 0;Contact con;//con 通讯录对象InitContact(&con);//初始化通讯录do {menu();printf("请输入你的选择:>");scanf("%d",&input);switch (input) {case ADD:AddContact(&con);//增加联系人break;case DEL:DelContact(&con);//删除联系人break;case SEARCH:SearchContact(&con);//查找联系人break;case MODIFY:ModifyContact(&con);//修改联系人信息break;case SHOW:ShowContact(&con);//显示全部联系人break;case SORT:SortContact(&con);//对联系人进行排序break;case CLEAR:InitContact(&con);//清空通讯录break;case EXIT:printf("退出通讯录!\n");break;default:Sleep(300);system("cls");//清屏printf("输入错误,请重新输入!\n");}} while (input);return 0;
}

contact.c

#define _CRT_SECURE_NO_WARNINGS 
#include "contact.h"//用于实现函数//初始化通讯录
void InitContact(Contact *pc) 
{assert(pc);//断言一下,避免空指针//将通讯录数据置0memset(pc->data,0,sizeof(pc->data)); //这里使用的内存函数,也可以使用for循环进行pc->sz = 0;//将记录通讯录信息个数置0
}//增加联系人
void AddContact(Contact* pc) 
{assert(pc);//首先应该判断通讯录是否已满if (pc->sz == MAX) {printf("通讯录已满,无法添加!\n");return;}Sleep(300);system("cls");//清屏//增加的信息//名字 年龄 性别 电话 地址printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n","名字","年龄","性别","电话","地址");printf("----------------------------------------------------------------------------\n");//增加信息printf("请输入名字:");scanf("%s",pc->data[pc->sz].name);printf("请输入年龄:");scanf("%d",&(pc->data[pc->sz].age));printf("请输入性别:");scanf("%s", pc->data[pc->sz].sex);printf("请输入电话:");scanf("%s", pc->data[pc->sz].tele);printf("请输入地址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("增加成功\n");Sleep(1000);system("cls");//清屏
}//显示全部联系人
void ShowContact( const Contact* pc)
{assert(pc);if (pc->sz == 0){printf("通讯录为空!\n");Sleep(1000);system("cls");//清屏return;}printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc -> sz;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->sz;i++){if (strcmp(pc->data[i].name,name) == 0) {return i;}}return -1;
}//删除联系人
void DelContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法删除!\n");Sleep(1000);system("cls");//清屏return;}char name[NAME_MAX];printf("输入要删除的名字:");scanf("%s",&name);int ret = FindByName(pc,name);if (ret == -1){printf("要删除的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}int i = 0;//进行删除的操作for (i = ret; i < pc->sz - 1;i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");
}//查找联系人
void SearchContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];Sleep(1000);system("cls");//清屏printf("请输入要查找人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要查找的联系人不存在\n");//Sleep(1000);//system("cls");//清屏return;}Sleep(1000);system("cls");//清屏//显示出查找的联系人printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-18s\n",pc->data[ret].name,pc->data[ret].age,pc->data[ret].sex,pc->data[ret].tele,pc->data[ret].addr);Sleep(3000);
}enum option_menu 
{EXIT,NAME ,AGE,SEX,TELE,ADDR
};
//修改联系人信息
void ModifyContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];printf("请输入要修改联系人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要修改的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}//修改联系人printf("**********\n");printf("#1. 名字 *\n#2. 年龄 *\n#3. 性别 *\n#4. 电话 *\n#5. 地址 *\n#0. 返回 *\n");printf("**********\n");int input = 0;do{//option_menu();printf("请选择你要的信息:>\n");scanf("%d", &input);switch (input){case NAME:printf("请输入名字:\n");scanf("%s", pc->data[ret].name);break;case AGE:printf("请输入年龄:\n");scanf("%d", &(pc->data[ret].age));break;case SEX:printf("请输入性别:\n");scanf("%s", pc->data[ret].sex);break;case TELE:printf("请输入电话:\n");scanf("%s", pc->data[ret].tele);break;case ADDR:printf("请输入地址:\n");scanf("%s", pc->data[ret].addr);break;case EXIT:printf("返回主界面\n");return;default:printf("输入错误,请重新输入\n");break;}} while (input);}int cmp_name(const void* s1,const void* s2) 
{return strcmp(((Contact*)s1)->data->name, ((Contact*)s2)->data->name);
}
int cmp_age(const void* s1,const void* s2)
{return ((Contact*)s1)->data->age - ((Contact*)s2)->data->age;
}
//排序
void SortContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法排序 !");return;}int input = 0;printf("***********\n");printf("# 1. 名字 *\n# 2. 年龄 *\n");printf("***********\n");printf("请选择排序的方法:");scanf("%d",&input);if (input == 1) {//按名字进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_name);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; 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);}}else if (input == 2) {//按年龄进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_age);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; 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);}}
}

contact.h

#pragma once#include<stdio.h>
#include<assert.h>
#include<string.h>
#include<stdlib.h>
#include<windows.h>#define NAME_MAX 20
#define SEX_MAX 5
#define TELE_MAX 12
#define ADDR_MAX 30#define MAX 1000 //用于存放通信录信息的条数
//用于声明函数typedef struct PeoInfo 
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tele[TELE_MAX];char addr[ADDR_MAX];
}PeoInfo;typedef struct Contact 
{PeoInfo data[MAX];//存放通讯录数据int sz;//记录通讯录存了多少个数据
}Contact;//初始化通讯录
void InitContact(Contact * pc);//增加联系人
void AddContact(Contact* pc);//显示全部联系人
void ShowContact(Contact* pc);//删除联系人
void DelContact(Contact* pc);//查找联系人
void SearchContact(Contact* pc);//修改联系人信息
void ModifyContact(Contact* pc);//排序
void SortContact(Contact* pc);

http://www.dtcms.com/a/601000.html

相关文章:

  • 17网站一起做网店如何下单下载站用什么网站系统
  • VMware替代 | ZStack ZSphere虚拟化平台金融级高可用能力解析
  • Go语言编译器源码 | 深入解析Go编译器的设计与实现原理
  • Bootstrap4 文字排版
  • 第13节 93年高能所被入侵,开启中国网络安全发展进程
  • [学习笔记] An Introduction to Flow Matching and Diffusion Models
  • 从零开始的Qt开发指南:(三)信号与槽的概念与使用
  • 视频网站怎么搭建wordpress站点标题图片
  • 加强学校网站建设的要求小说网站建设教程
  • 软考 系统架构设计师历年真题集萃(199)—— 2025年11月系统架构设计师真题2
  • 零门槛部署:在AMD MI300X上极速部署运行GPT-OSS 120B全流程实践
  • 视觉学习——理清机器学习:分类、流程与技术家族的关系
  • 建设网站为什么要备案只有一个页面的网站
  • 分布式专题——54 ElasticSearch集群架构生产最佳实践
  • python+django/flask的宠物用品系统vue
  • 网泰网站建设哪里可以引流到精准客户呢
  • 自相关和互相关、卷积计算流程演示
  • 淮安网站建设制作国精产品w灬源码1688说明
  • 探索K8s与AI的结合:PyTorch训练任务在k8s上调度实践
  • Linux操作系统学习之---初识网络
  • 怎么破解别人做的付费网站网络营销的应用研究论文
  • phpMyAdmin Docker 容器化部署指南
  • 集成技术如何支撑“双十一零售高峰?”
  • 如何正确下载安装官方.NET Framework 4.6?3种方法详解(附4.6.1、4.6.2版本对比)
  • 串流经验:云玩加、 Parsec、Zerotier
  • F045 vue+flask棉花病虫害CNN识别+AI问答知识neo4j 图谱可视化系统深度学习神经网络
  • 某东电商平台的MySQL面试知识点分析
  • wordpress自适应站点网站建设 甲方欠款 如何处理
  • linux本地wordpress手机优化助手怎么删除
  • CLION打开git-bash