首页 > 其他分享 >实现C语言通讯录

实现C语言通讯录

时间:2024-09-30 19:21:27浏览次数:3  
标签:sz name 实现 C语言 pc Contact 通讯录 printf data

#实现C语言通讯录
简简单单写一个C语言

一:函数的定义

  • 通过MAX ,NAME_MAX,SEX_MAX,ADDR_MX ,TETE_MAX 定义结构体成员的数量
  • 通过typedef重命名结构体为PeoInfo;
  • 在定义结构体struct Contact的PeoInfo data用来存放结构体里面人的信息和通过sz来访问人的信息
#pragma once
//人的信息
#include<stdio.h>
#include<assert.h>
#define MAX 100
#define NAME_MAX 20
#define  SEX_MAX 5
#define  ADDR_MX 30 
#define TETE_MAX 12
typedef struct PeoInfo
{
	char name[NAME_MAX];
	int age;
	char sex[SEX_MAX];
	char addr[ADDR_MX];
	char tele[TETE_MAX];
}PeoInfo;
typedef struct Contact
{
	PeoInfo data[100];//存放人的信息
	int sz;//当前存放的数目
}Contact;

//初始化通讯录
void Initcontact(Contact* pc);
//增加联系人
void AddContact(Contact* pc);
//显示通讯录信息
void ShowContact(const Contact* pc);
//删除通讯录信息
void DelContact(Contact* pc);
//查找指定联系人
void SearchContact(const Contact* pc);
//修改指定联系人
void ModifyContact(Contact* pc);

二:函数的实现

  • 通过memset库函数来初始化结构体
  • 再通过pc->data[pc->sz]来实现AddContact
  • 打印pc->data[i]的信息,通过ShowContact实现
  • 通过FindByname来找到名字对应的pc->data[i]里面的i;
  • 实现DelContact,SearchContact函数
  • DelContact删除函数,但是要记得pc->data[i] = pc->data[i + 1],用后面的元素替代前面的数据,但是要记得sz–去掉一个元素(已经删除了一个元素),找不到的话返回-1,
  • ModifyContact和DelContact实现的函数差不多,只是要打印pc->data[pos]的各元素信息
#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
void InitContact(Contact* pc) {
	pc->sz = 0;
	memset(pc->data, 0, sizeof(pc->data));
}
void AddContact(Contact* pc) {
	assert(pc != NULL);
	if (pc->sz == 100) {
		printf("通讯录已经满了");
		return;
	}
	//增加一个人的信息
	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].addr);
	printf("请输入电话:>");
	scanf("%s", pc->data[pc->sz].tele);
	pc ->sz++;
}
void ShowContact(const Contact* pc) {
	int i = 0;
	printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "姓名", "年龄", "性别", "地址", "电话");
	for (i = 0; i < pc->sz; i++) {
		//正数是右边对齐,负数是左边对齐
		printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[i].name,
			pc->data[i].age,
			pc->data[i].sex,
			pc->data[i].addr,
			pc->data[i].tele);
	}                                  
}
int FindByname(const Contact*pc,char name[]){
	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) {
	char name[NAME_MAX] = { 0 };
	if (pc->sz == 0) {
		printf("通讯录为空,不允许删除");
	}
	//删除
	//要删除人的名字
	printf("请输入你要删除人的名字:>");

	scanf("%s", name);
	int ret = FindByname(pc, name);
	if (-1 == ret) {
		printf("要删除的人不存在");
		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(const Contact* pc) {
	char name[NAME_MAX] = { 0 };
	printf("请输入要查找的人的名字:>");
	scanf("%s", name);
	int pos = FindByname( pc, name);
		if (-1 == pos) {
			printf("查找的人不存在");
    		return;
     	}
		printf("%20s\t%4s\t%5s\t%20s\t%12s\n", "姓名", "年龄", "性别", "地址", "电话");
		
			//正数是右边对齐,负数是左边对齐
			printf("%20s\t%4d\t%5s\t%20s\t%12s\n", pc->data[pos].name,
				pc->data[pos].age,
				pc->data[pos].sex,
				pc->data[pos].addr,
				pc->data[pos].tele);
		
 }
void ModifyContact(Contact* pc) {
	char name[NAME_MAX] = { 0 };
	printf("请输入要修改人的名字:>");
	scanf("%s", name);
	int pos = FindByname(pc, name);
	if (-1 == pos) {
		printf("修改的人不存在");
		//return;
	}
	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].addr);
	printf("请输入电话:>");
	scanf("%s", pc->data[pos].tele);
	printf("修改完成\n");
}

三函数的执行语句

  • 创建通讯录Contact con
  • 通过选择不同语句执行不同函数
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include"contact.h"
void menu() {
	printf("*********************************\n");
	printf("*********************************\n");
	printf("*********** 0 - exit*************\n");
	printf("****** 1 - Add  2 - del**********\n");
	printf("****** 3 - Search 4 - Modify*****\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 0:
			printf("退出\n");
			break;
		default:
			printf("选择错误->");
			break;
		}
		

		
	} while (input);
}

标签:sz,name,实现,C语言,pc,Contact,通讯录,printf,data
From: https://blog.csdn.net/2301_81134141/article/details/142487230

相关文章

  • C语言文件操作(续写)
    文章目录C语言文件操作(续写)文件的随机读写fseekftellrewind文件结束判定被错误使用的feof二进制文件的例子:C语言文件操作(续写)文件的随机读写fseek根据文件指针的位置和偏移量来定位文件指针。#include<stdio.h>intmain(){FILE*pFile;pFi......
  • 鹏哥C语言54.一维数组(知识点)
    1.1一维数组的创建✌️✌️✌️ 举个例子:! 1.2数组的初始化 特别注意上面第6个,arr6[]实际上算是arr6[7]因为字符串末尾默认放了一个\0......
  • Flutter 实现骨架屏
    Flutter实现骨架屏 合集-flutter(1) 1.Flutter实现骨架屏09-30收起 什么是骨架屏在客户端开发中,我们总是需要等待拿到服务端的响应后,再将内容呈现到页面上,那么在用户发起请求到客户端成功拿到响应的这段时间内,应该在屏幕上呈现点什么好呢?答案是:骨架屏......
  • 【C++ STL】深入理解string类的底层实现
    string类的模拟实现一.string的构造与析构函数1.普通构造函数与析构函数2.拷贝构造的浅拷贝所带来的问题3.如何实现深拷贝二.运算符重载1.赋值运算符重载2.大小比较相关的运算符重载三.迭代器的实现四.string常用操作的实现1.静态const成员npos的定义2.插入操作3.查找......
  • .Net 依赖注入深入探索,做一个DI拓展,实现一个简易灵活的 自动依赖注入框架
    .Net依赖注入深入探索,做一个DI拓展,实现一个简易灵活的自动依赖注入框架 合集-.Net框架探索(2) 1..NetWeb项目中,实现轻量级本地事件总线框架09-272.依赖注入深入探索,做一个DI拓展,实现一个简易灵活的自动依赖注入框架09-30收起 一、依赖注入相关知识1.1......
  • c语言第六章2.0
    题3,求一个3*3矩阵对角线之和#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>#include<stdlib.h>intmain(){   intstr[3][3];   for(inti=0;i<3;i++){      for(intj=0;j<3;j++){         str[i][j]=rand();//生......
  • Vue3基于SpringBoot的高校学生实习综合服务平台设计与实现
    目录功能和开发技术介绍具体实现截图开发核心技术介绍:技术创新点vue3和vue2的区别:核心代码部分展示非功能需求分析系统开发流程系统运行步骤软件测试源码获取功能和开发技术介绍本课题拟采用主流的MVC架构、开发工具idea、java语言编程、MySQL数据库技术、Vue.js技......
  • vue基于SpringBoot的在线个性化电影推荐与观影社交平台的设计与实现
    目录毕设制作流程功能和技术介绍系统实现截图开发核心技术介绍:使用说明开发步骤编译运行代码执行流程核心代码部分展示可行性分析软件测试详细视频演示源码获取毕设制作流程(1)与指导老师确定系统主要功能;(2)做需求分析及功能模块划分;(3)指导老师通过后,设计出用例图,E-R......
  • codeforces round 975 E(div.2)(lambda表达式实现dfs,min_element函数,一定要优化重复的
    解题历程:看到题目要求要用最少的消除次数让所有叶子深度相同,通过观察,那么就只需要将所有深度都尝试一遍就行了,可是我当时没多想就用dfs记录所有节点的深度,单独将所有叶子和该叶子的深度存起来,记录最大的深度,从最大深度尝试到深度0,对于深度小于当前尝试深度的叶子,用dfs的方式将与......
  • 【代码实现】opencv 高斯模糊和pytorch 高斯模糊
    wiki百科GaussianBlur,也叫高斯平滑,是在AdobePhotoshop、GIMP以及Paint.NET等图像处理软件中广泛使用的处理效果,通常用它来减少图像噪声以及降低细节层次。opencv实现opencv实现高斯滤波有两种方式,1、是使用自带的cv2.GaussianBlur,2、自己构造高斯kernel,然后调用cv......