C语言实现静态版通讯录的代码分享

目录
  • 前言
  • 通讯录设计的关键思想点分析
  • 通讯录界面(meun)设计
  • 增加信息功能实现代码
  • 删除信息功能实现代码
  • 查询信息功能实现代码
  • 修改信息功能实现代码
  • 按年龄升序排序信息功能实现代码
  • 显示信息功能实现代码
  • 通讯录完整代码
  • 测试过程展示

前言

哈喽各位友友们,我今天又学到了很多有趣的知识,现在迫不及待的想和大家分享一下!我仅已此文,手把手带领大家在学习C语言知识的同时,并实现一个静态版的通讯录!主要运用了结构体,一维数组,函数,分支与循环语句等等知识,以及分文件书写项目思想。都是精华内容,可不要错过哟!!!

通讯录设计的关键思想点分析

首先根据我们通讯录的业务需求设计好我们的个人信息结构体(PeoInfor)。这里设计的每一个人的信息包括:姓名,年龄,性别,电话,地址。然后就可以设计出我们具体的结构体啦!

为了方便后面代码的设计传参,这里再设计一个结构体(Contact),包括能够存放1000个通讯信息的空间和sz记录通讯录中信息的条数。

先设计好通讯录需要完成什么功能,这里是设计出增加信息、删除信息、查询信息、修改信息、按年龄排序信息、显示信息、退出通讯录这几大功能。

这里使用到了memset,memmove内存函数,大家可以先去查找学习一下。这里利用menmset函数,给通讯录进行初始化操作。用menmove实现通讯录的删除功能。

增加功能设计时,需要考虑特殊情况,如果通讯录满了就不能再添加啦。删除功能设计时也要考虑特殊情况,如果通讯录为空(sz为0),则就不能删除了。这里的排序功能用的是冒泡排序实现。

整体的编写风格采用的是分文件编写的方式:Contact.h文件,负责函数、结构体声明、define常量的定义、枚举的定义、头文件的包含。Contact.c文件,负责通讯录各个功能函数体的实现。test.c文件,负责测试通讯录的功能。

通讯录界面(meun)设计

通讯录菜单界面(meun)设计的代码编写:

void meun()
{
    printf("**************************************\n");
    printf("******   1.Add      2.Del      *******\n");
    printf("******   3.Search   4.Modify   *******\n");
    printf("******   5.Sort     6.Print    *******\n");
    printf("******   0.Exit                *******\n");
    printf("**************************************\n");
}

界面成果图展示:

增加信息功能实现代码

//增加通讯录信息
void AddContact(Contact* pc)
{
    if (DATA_MAX == pc->sz)
    {
        printf("通讯录信息存储空间已满!\n");
        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].tele);
    printf("请输入住址:> ");
    scanf("%s", pc->data[pc->sz].addr);
    printf("信息添加成功!\n");
    pc->sz++;
}

删除信息功能实现代码

void DelContact(Contact* pc)
{
    char name[NAME_MAX];
    printf("请输入要删除的人的名字:> ");
    scanf("%s", name);
    if (pc->sz == 0)
    {
        printf("通讯录已空!\n");
        return;
    }
    int pos = FindByName(pc, name);
    if (pos == -1)
    {
        printf("通讯录中无此要删除的人的信息\n");
        return;
    }
    memmove(pc->data + pos, pc->data + pos + 1, (pc->sz - 1 - pos) * sizeof(pc->data[0]));
    pc->sz--;
    printf("删除成功!\n");
}

查询信息功能实现代码

//查询通讯录信息
void SearchContact(Contact* pc)
{
    char name[NAME_MAX];
    printf("请输入要查询的人的名字:> ");
    scanf("%s", name);
    int pos = FindByName(pc, name);
    if (pos == -1)
    {
        printf("通讯录中无此查询人的信息\n");
        return 0;
    }
    printf("%-20s %-10s %-15s %-30s %-30s\n", "姓名", "年龄", "性别", "电话", "地址");
    printf("%-20s %-10d %-15s %-30s %-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)
{
    char name[NAME_MAX];
    printf("请输入要修改的人的名字:> ");
    scanf("%s", name);
    int pos = FindByName(pc, name);
    if (pos == -1)
    {
        printf("通讯录中无此人的信息\n");
        return 0;
    }
    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");

}

按年龄升序排序信息功能实现代码

//年龄排序
void SortContact(Contact* pc)
{
    for (int i = 0; i < pc->sz; i++)
    {
        for (int j = 0; j < pc->sz - 1 - i; j++)
        {
            if (pc->data[j].age > pc->data[j + 1].age)
            {
                PeoInfor tmp = pc->data[j];
                pc->data[j] = pc->data[j + 1];
                pc->data[j + 1] = tmp;
            }
        }
    }
    printf("排序成功!\n");
}

显示信息功能实现代码

//打印通讯录信息
void PrintContact(Contact* pc)
{
    assert(pc);
    printf("%-20s %-10s %-15s %-30s %-30s\n","姓名","年龄","性别","电话","地址");
    for (int i = 0; i < pc->sz; i++)
    {
        printf("%-20s %-10d %-15s %-30s %-30s\n", pc->data[i].name, pc->data[i].age,
                pc->data[i].sex, pc->data[i].tele, pc->data[i].addr);
    }
}

通讯录完整代码

通讯录头文件代码编写:

#pragma once
#include<stdio.h>
#include<assert.h>
#include<string.h>
#define NAME_MAX 20
#define SEX_MAX  3
#define TELE_MAX 20
#define ADDR_MAX 30
#define DATA_MAX 1000
enum
{
	EXIT,
	ADD,
	DEL,
	SEARCH,
	MODIFY,
	SORT,
	PRINT
};

typedef struct PeoInfor
{
	char name[NAME_MAX];
	int age;
	char sex[SEX_MAX];
	char tele[TELE_MAX];
	char addr[ADDR_MAX];
}PeoInfor;

typedef struct Contact
{
	PeoInfor data[DATA_MAX];
	int sz;
}Contact;

//初始化通讯录
void InitContact(Contact* pc);
//增加通讯录信息
void AddContact(Contact* pc);
//删除通讯录信息
void DelContact(Contact* pc);
//查询通讯录信息
void SearchContact(Contact* pc);
//修改通讯录信息
void ModifyContact(Contact* pc);
//排序
void SortContact(Contact* pc);
//打印通讯录信息
void PrintContact(Contact* pc);

通讯录功能文件代码编写:

#define _CRT_SECURE_NO_WARNINGS 1
#include"Contact.h"

//初始化通讯录
void InitContact(Contact* pc)
{
	assert(pc);
	memset(pc->data, 0, sizeof(pc->data));
	pc->sz = 0;
}

//增加通讯录信息
void AddContact(Contact* pc)
{
	if (DATA_MAX == pc->sz)
	{
		printf("通讯录信息存储空间已满!\n");
		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].tele);
	printf("请输入住址:> ");
	scanf("%s", pc->data[pc->sz].addr);
	printf("信息添加成功!\n");
	pc->sz++;
}
int  FindByName(Contact* pc, char name[])
{
	for (int 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];
	printf("请输入要删除的人的名字:> ");
	scanf("%s", name);
	if (pc->sz == 0)
	{
		printf("通讯录已空!\n");
		return;
	}
	int pos = FindByName(pc, name);
	if (pos == -1)
	{
		printf("通讯录中无此要删除的人的信息\n");
		return;
	}
	memmove(pc->data + pos, pc->data + pos + 1, (pc->sz - 1 - pos) * sizeof(pc->data[0]));
	pc->sz--;
	printf("删除成功!\n");
}
//查询通讯录信息
void SearchContact(Contact* pc)
{
	char name[NAME_MAX];
	printf("请输入要查询的人的名字:> ");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (pos == -1)
	{
		printf("通讯录中无此查询人的信息\n");
		return 0;
	}
	printf("%-20s %-10s %-15s %-30s %-30s\n", "姓名", "年龄", "性别", "电话", "地址");
	printf("%-20s %-10d %-15s %-30s %-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)
{
	char name[NAME_MAX];
	printf("请输入要修改的人的名字:> ");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (pos == -1)
	{
		printf("通讯录中无此人的信息\n");
		return 0;
	}
	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");

}
//年龄排序
void SortContact(Contact* pc)
{
	for (int i = 0; i < pc->sz; i++)
	{
		for (int j = 0; j < pc->sz - 1 - i; j++)
		{
			if (pc->data[j].age > pc->data[j + 1].age)
			{
				PeoInfor tmp = pc->data[j];
				pc->data[j] = pc->data[j + 1];
				pc->data[j + 1] = tmp;
			}
		}
    }
	printf("排序成功!\n");
}
//打印通讯录信息
void PrintContact(Contact* pc)
{
	assert(pc);
	printf("%-20s %-10s %-15s %-30s %-30s\n","姓名","年龄","性别","电话","地址");
	for (int i = 0; i < pc->sz; i++)
	{
		printf("%-20s %-10d %-15s %-30s %-30s\n", pc->data[i].name, pc->data[i].age,
			    pc->data[i].sex, pc->data[i].tele, pc->data[i].addr);
	}
}

通讯录测试文件代码编写:

#define _CRT_SECURE_NO_WARNINGS 1
#include"Contact.h"

void meun()
{
	printf("**************************************\n");
	printf("******   1.Add      2.Del      *******\n");
	printf("******   3.Search   4.Modify   *******\n");
	printf("******   5.Sort     6.Print    *******\n");
	printf("******   0.Exit                *******\n");
	printf("**************************************\n");
}

void test()
{
	Contact p;
	int input = 0;
	InitContact(&p);
	do
	{
		meun();
		printf("请输入功能选项:>\n");
		scanf("%d", &input);
		switch (input)
		{
		case EXIT:
			printf("已退出通讯录!\n");
			break;
		case ADD:
			AddContact(&p);
			break;
		case DEL:
			DelContact(&p);
			break;
		case SEARCH:
			SearchContact(&p);
			break;
		case MODIFY:
			ModifyContact(&p);
			break;
		case SORT:
			SortContact(&p);
			break;
		case PRINT:
			PrintContact(&p);
			break;
		default:
			printf("输入错误,请重新输入!\n");
			break;
		}
	} while (input);

}

int main()
{

	test();
	return 0;
}

测试过程展示

以上就是C语言实现静态版通讯录的代码分享的详细内容,更多关于C语言静态通讯录的资料请关注我们其它相关文章!

(0)

相关推荐

  • C语言实现静态版通讯录的示例代码

    目录 前言 通讯录需求分析 功能介绍 实现思路 代码实现 test.c contact.c contact.h 效果图 前言 大家好~今天要实现一个非常有意思的东西–通讯录. 通讯录需求分析 为了实现通讯录管理系统,为此,要保证实现以下的功能: 能够存放1000个联系人的信息.每个人的信息包含:名字.年龄.性别.电话.地址.除此之外,还是实现:增加人的信息.删除人的信息.修改指定人的信息.查找指定人的信息.清空联系人的信息.显示联系人的信息.排序通讯录的信息. 功能介绍 1.增加联系人信息 2.

  • C语言静态版通讯录的设计与实现

    目录 1. 配置运行环境 2. 通讯录的实现 2.1 通讯录的功能目录 2.2 增加信息功能代码的实现 2.3 显示信息功能代码的实现 2.4 删除信息功能代码的实现 2.5 查询信息功能代码的实现 2.6 修改信息功能代码的实现 2.7 按名字排序信息功能代码的实现 3. 完整静态版本通讯录的全部源码 3.1 contact.c 3.2 contact.h 3.3 test.c 4. 静态版本通讯录的缺点 1. 配置运行环境 本通讯录运用到了三个文件 test.c //测试通讯录的相关功能 c

  • C语言实现通讯录的方法(包括静态版本和动态版本)

    目录 1.静态通讯录的实现 实现的方法: 2.动态通讯录的实现 实现的方法: 3.总结 1.静态通讯录的实现 实现的方法: 我们采用的方法就是工程形势,实现将功能和定义以及测试分成三个文件,其中定义放在.h文件,实现和测试放在.c文件当中. (1)contact.h文件的基本实现: #pragma once//防止头文件重复定义 #define NAME_MAX 20 #define SEX_MAX 5 #define TELE_MAX 12 #define ADDR_MAX 30 #defin

  • C语言实现简易通讯录(静态版本)的代码分享

    目录 一.通讯录 1.演示效果 2.完整代码 二.代码解析 1.宏定义及结构体声明 2.主菜单函数 3.主函数 4.查找函数 5.初始化联系人信息 6.添加联系人信息 7.显示所有联系人信息 8.删除指定联系人信息 9.修改联系人信息 10.查找指定联系人 11.按照姓氏对联系人信息排序 12.清空所有联系人信息 一.通讯录 1.演示效果 2.完整代码 #define _CRT_SECURE_NO_WARNINGS 1 //#include "ConTacts.h" #include

  • C语言实现静态版通讯录的代码分享

    目录 前言 通讯录设计的关键思想点分析 通讯录界面(meun)设计 增加信息功能实现代码 删除信息功能实现代码 查询信息功能实现代码 修改信息功能实现代码 按年龄升序排序信息功能实现代码 显示信息功能实现代码 通讯录完整代码 测试过程展示 前言 哈喽各位友友们,我今天又学到了很多有趣的知识,现在迫不及待的想和大家分享一下!我仅已此文,手把手带领大家在学习C语言知识的同时,并实现一个静态版的通讯录!主要运用了结构体,一维数组,函数,分支与循环语句等等知识,以及分文件书写项目思想.都是精华内容,可不

  • C语言实现动态版通讯录的示例代码

    目录 前言 contact.c contact.h test.c 前言 大家好~今天是通讯录的动态版本实现,希望对大家对知识的掌握有所提升! contact.c #include"contact.h" //初始化通讯录 void InitContact(Contact* pc) { assert(pc); pc->sz = 0; pc->data = (PeoInfo*)calloc(DEFAULT_SZ, sizeof(PeoInfo)); if (NULL == pc-

  • C语言实现的学生选课系统代码分享

    好久没玩过C语言了,上一次还是在大二的时候...废话不多说,这里有一个C语言实现的学生选课系统代码,分享给大家,具体如下: #include<stdio.h> #include<stdlib.h> int N1,N2,kk1,kk2,kk3; struct couse * head1; struct student * head2; struct couse//课程信息结构体 { int num1; char name1[20]; int score; int nelepeo; /

  • js贪吃蛇网页版游戏特效代码分享(挑战十关)

    js贪吃蛇网页版游戏特效,经测试图片切换过程非常酷,相信大家一定都玩过这个经典小游戏吧,但是它是怎么实现的呐,感兴趣的朋友快来学习学习吧 运行效果图:----------------------查看效果----------------------- 小提示:浏览器中如果不能正常运行,可以尝试切换浏览模式. 为大家分享的js贪吃蛇网页版游戏特效代码如下 <body><title>js贪吃蛇网页版游戏特效</title></body> <script>

  • ASP页面静态化批量生成代码分享(多种方法)

    1.ASP两种简单的生成静态首页的方法 为什么要生成静态首页? 1.如果你首页读取的数据库次数比较多,速度很慢,而且占用很多服务器资源.使用静态页面访问速度当然快多了 2.搜索引擎容易搜索到 3.如果程序出问题,也能保证首页能访问. 4.其他的太多,自己想:) 应用方式: 如果你的首页是index.asp,你可以生成index.htm (默认访问顺序必须是index.htm,index.asp).这样访问者第一次访问到你的网站的时候打开的是index.htm .你可以把网站首页的链接做成inde

  • Go语言实现机器大小端判断代码分享

    golang语言如何判断机器的大小端? 如下代码供参考: 复制代码 代码如下: package main     import (       "fmt"      "unsafe"  )     const N int = int(unsafe.Sizeof(0))     func main() {       x := 0x1234       p := unsafe.Pointer(&x)       p2 := (*[N]byte)(p)     

  • c语言实现系统时间校正工具代码分享

    复制代码 代码如下: //*******************************************************************//Time Protocol是一种非常简单的应用层协议.它返回一个未格式化的32位二进制数字, //这个数字描述了从1900年1月1日午夜到现在的秒数.服务器在端口37监听协议请求,以 //TCP/IP或者UDP/IP格式返回响应.将服务器的返回值转化为本地时间是客户端程序的责任. //这里使用的时间服务器是129.132.2.21,更

  • python版飞机大战代码分享

    利用pygame实现了简易版飞机大战.源代码如下: # -*- coding:utf-8 -*- import pygame import sys from pygame.locals import * from pygame.font import * import time import random class Hero(object): #玩家 英雄类 def __init__(self, screen_temp): self.x = 210 self.y = 700 self.life

随机推荐