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 <assert.h>
#include <stdio.h>
#define MAX 30
#define NAME 20
#define TEL 20
#define ADR 30
struct PopInfo {//声明一个结构体用来保存个人信息
	char name[NAME];//姓名
	int age;//年龄
	char tel[TEL];//手机号
	char adr[ADR];//住址
};
struct Contact {
	struct PopInfo data[MAX];//用结构体数组来存储多个人的信息
	int sz;//用来记录存储几个人的信息
};
void InitContact(struct Contact* con)//初始化联系人信息
{
	assert(con);
	memset(con->data, 0, MAX * sizeof(struct PopInfo));
	con->sz = 0;
}
void AddContact(struct Contact* con)//添加联系人信息
{
	assert(con);
	printf("请输入姓名:");
	scanf("%s", con->data[con->sz].name);
	printf("请输入年龄:");
	scanf("%d", &(con->data[con->sz].age));
	printf("请输入手机号:");
	scanf("%s", con->data[con->sz].tel);
	printf("请输入住址:");
	scanf("%s", con->data[con->sz].adr);
	con->sz++;
	printf("成功添加联系人!\n");
}
void ShowContact(struct Contact* con)//显示所有联系人信息
{
	int i = 0;
	printf("%-20s\t%-20s\t%-20s\t%-20s\t\n", "姓名", "年龄", "手机号", "住址");
	for (i = 0; i < con->sz; i++)
	{
		printf("%-20s\t%-20d\t%-20s\t%-20s\t\n", con->data[i].name, con->data[i].age, con->data[i].tel, con->data[i].adr);
	}
}
int Find(struct Contact* con)//根据姓名查找存放联系人信息的数组下标
{
	char name[20];
	scanf("%s", name);
	int i = 0;
	for (i = 0; i < con->sz; i++)
	{
		if (strcmp(con->data[i].name, name) == 0)
		{
			return i;
			break;
		}
	}
	return -1;
}
void DelContact(struct Contact* con)//删除指定联系人信息函数
{
	assert(con);
	printf("请输入你要删除的联系人姓名:");
	/*char name[20];
	printf("请输入你要删除的联系人姓名:");
	scanf("%s", name);
	int i = 0;
	for (i = 0; i < con->sz; i++)
	{
		if (strcmp(con->data[i].name, name) == 0)
		{
			printf("删除成功!\n");
			con->sz--;
			break;
		}
	}*/
int i = Find(con);
if (i == -1)
{
	printf("未找到你要删除的联系人\n");
}
else
{
	int j = 0;
	for (j = i; j <= con->sz; j++)
	{
		con->data[j] = con->data[j + 1];
	}
	con->sz--;
	printf("删除成功!\n");
}
}
void ModContact(struct Contact* con)//修改联系人信息
{
	assert(con);
	printf("请输入你要修改的联系人姓名:");
	/*char name[20];
	printf("请输入你要修改的联系人姓名:");
	scanf("%s", name);
	int i = 0;
	for (i = 0; i < con->sz; i++)
	{
		if (strcmp(con->data[i].name, name) == 0)
		{
			printf("找到要修改的联系人!\n");
			break;
		}
	}*/
	int i = Find(con);
	if (i == -1)
	{
		printf("未找到你要删除的联系人\n");
	}
	else
	{
		printf("请输入姓名:");
		scanf("%s", con->data[i].name);
		printf("请输入年龄:");
		scanf("%d", &(con->data[i].age));
		printf("请输入手机号:");
		scanf("%s", con->data[i].tel);
		printf("请输入住址:");
		scanf("%s", con->data[i].adr);
		printf("成功修改联系人信息!\n");
	}
}
void SearchContact(struct Contact* con)//查找指定联系人
{
	assert(con);//断言,con不能指向NULL
	printf("请输入你要查找的联系人姓名:");
	/*char name[20];
	printf("请输入你要查找的联系人姓名:");
	scanf("%s", name);
	int i = 0;
	for (i = 0; i < con->sz; i++)
	{
		if (strcmp(con->data[i].name, name) == 0)
		{
			break;
		}
	}*/
	int i = Find(con);
	if (i == -1)
	{
		printf("没有找到你要查找的联系人!\n");
	}
	else
	{
		printf("%-20s\t%-20s\t%-20s\t%-20s\t\n", "姓名", "年龄", "手机号", "住址");
		printf("%-20s\t%-20d\t%-20s\t%-20s\t\n", con->data[i].name, con->data[i].age, con->data[i].tel, con->data[i].adr);
	}
}
int cmp_name(const void* e1, const void* e2)//qsort中的比较函数
{
	return strcmp(((struct PopInfo*)e1)->name, ((struct PopInfo*)e2)->name);//只能对字符及字符串排序,如果是数字,会出错
}
void Sort_name_Contact(struct Contact* con)//qsort函数排序
{
	qsort(con->data, con->sz, sizeof(struct PopInfo), cmp_name);
	printf("排序成功\n");//名字按照字母的ASCII码值从小到大排序
}
void ClearContact(struct Contact* con)//清空所有联系人信息
{
	char str[10];
	while (1)
	{
		printf("确定清空通讯录吗?(yes/no):");
		scanf("%s", str);
		if (strcmp(str, "yes") == 0)
		{
			con->sz = 0;
			printf("已清空通讯录!\n");
			break;
		}
		else if (strcmp(str, "no") == 0)
		{
			printf("已取消!\n");
			break;
		}
		else
			printf("输入错误,请重新输入!\n");
	}
}
enum um {//用枚举类型表示input的值
	Exit,//Exit是常量值0,退出程序
	Add,//Add是常量值1,添加联系人信息
	Del,//Del是常量值2,删除指定联系人信息
	Mod,//3,修改联系人信息
	Search,//4,查找联系人信息
	Sort_name,//5,按照姓氏对联系人信息排序
	Show,//6,显示联系人信息
	Clear//7,清空所有联系人信息
};

void menu()
{
	printf("*******************************\n");
	printf("***  1.添加联系人信息        **\n");
	printf("***  2.删除指定联系人信息    **\n");
	printf("***  3.修改联系人信息        **\n");
	printf("***  4.查找联系人信息        **\n");
	printf("***  5.按照姓氏对联系人排序  **\n");
	printf("***  6.显示联系人信息        **\n");
	printf("***  7.清空所有联系人信息    **\n");
	printf("***  0.退出程序              **\n");
}
int main()
{
	int input = 0;
	struct Contact con;
	InitContact(&con);//初始化联系人信息
	do {
		menu();
		printf("请选择:");
		scanf("%d", &input);
		switch (input)
		{
		case Add:
			AddContact(&con);//添加联系人信息
			break;//break仅退出switch语句,不会退出do-while循环
		case Del:
			DelContact(&con);//删除指定联系人信息
			break;
		case Mod:
			ModContact(&con);//修改联系人信息
			break;
		case Search:
			SearchContact(&con);//查找指定联系人
			break;
		case Sort_name:
			Sort_name_Contact(&con);//按照姓氏对联系人信息排序
			break;
		case Show:
			ShowContact(&con);//显示所有联系人信息
			break;
		case Clear:
			ClearContact(&con);//清空所有联系人信息
			break;
		case Exit:
			printf("退出程序\n");
			break;
		default:
			printf("输入错误,请重新选择\n");
			break;
		}
	} while (input);
	return 0;
}

二、代码解析

1.宏定义及结构体声明

#include <assert.h>
#include <stdio.h>
#define MAX 30
#define NAME 20
#define TEL 20
#define ADR 30
struct PopInfo {//声明一个结构体用来保存个人信息
    char name[NAME];//姓名
    int age;//年龄
    char tel[TEL];//手机号
    char adr[ADR];//住址
};
struct Contact {
    struct PopInfo data[MAX];//用结构体数组来存储多个人的信息
    int sz;//用来记录存储几个人的信息
};

定义struct PopInfo结构体用来保存联系人的信息,再定义struct Contact,用来保存多个联系人的信息以及记录所存储联系人个数。

2.主菜单函数

void menu()
{
    printf("*******************************\n");
    printf("***  1.添加联系人信息        **\n");
    printf("***  2.删除指定联系人信息    **\n");
    printf("***  3.修改联系人信息        **\n");
    printf("***  4.查找联系人信息        **\n");
    printf("***  5.按照姓氏对联系人排序  **\n");
    printf("***  6.显示联系人信息        **\n");
    printf("***  7.清空所有联系人信息    **\n");
    printf("***  0.退出程序              **\n");
}

3.主函数

int main()
{
    enum um {//用枚举类型表示input的值
        Exit,//Exit是常量值0,退出程序
        Add,//Add是常量值1,添加联系人信息
        Del,//Del是常量值2,删除指定联系人信息
        Mod,//3,修改联系人信息
        Search,//4,查找联系人信息
        Sort_name,//5,按照姓氏对联系人信息排序
        Show,//6,显示联系人信息
        Clear//7,清空所有联系人信息
    };
    int input = 0;
    struct Contact con;
    InitContact(&con);//初始化联系人信息
    do {
        menu();
        printf("请选择:");
        scanf("%d", &input);
        switch (input)
        {
        case Add:
            AddContact(&con);//添加联系人信息
            break;//break仅退出switch语句,不会退出do-while循环
        case Del:
            DelContact(&con);//删除指定联系人信息函数
            break;
        case Mod:
            ModContact(&con);//修改联系人信息
            break;
        case Search:
            SearchContact(&con);//查找指定联系人
            break;
        case Sort_name:
            Sort_name_Contact(&con);//按照姓氏对联系人信息排序
            break;
        case Show:
            ShowContact(&con);//显示所有联系人信息
            break;
        case Clear:
            ClearContact(&con);
            break;
        case Exit:
            printf("退出程序\n");
            break;
        default:
            printf("输入错误,请重新选择\n");
            break;
        }
    } while (input);
    return 0;
}

4.查找函数

int Find(struct Contact* con)//根据姓名查找存放联系人信息的数组下标
{
    char name[20];
    scanf("%s", name);
    int i = 0;
    for (i = 0; i < con->sz; i++)
    {
        if (strcmp(con->data[i].name, name) == 0)
        {
            return i;
            break;
        }
    }
    return -1;
}

根据姓名查找存放联系人信息的数组下标,用于后来查找、删除、修改联系人信息时使用。

5.初始化联系人信息

void InitContact(struct Contact* con)//初始化联系人信息
{
    assert(con);
    memset(con->data, 0, MAX * sizeof(struct PopInfo));
    con->sz = 0;
}

assert(con);是判断指针con是否为空,判断memset(con->data, 0, MAX * sizeof(struct PopInfo))是将结构体struct Contact中struct PopInfo类型的数组data置为0。con->sz = 0;是将所记录的联系人个数置为0。

6.添加联系人信息

void AddContact(struct Contact* con)//添加联系人信息
{
    assert(con);
    printf("请输入姓名:");
    scanf("%s", con->data[con->sz].name);
    printf("请输入年龄:");
    scanf("%d", &(con->data[con->sz].age));
    printf("请输入手机号:");
    scanf("%s", con->data[con->sz].tel);
    printf("请输入住址:");
    scanf("%s", con->data[con->sz].adr);
    con->sz++;
    printf("成功添加联系人!\n");
}

注意在输入年龄的时候因为年龄是int类型,要用&符号取出地址,再进行赋值。

7.显示所有联系人信息

void ShowContact(struct Contact* con)//显示所有联系人信息
{
    int i = 0;
    printf("%-20s\t%-20s\t%-20s\t%-20s\t\n", "姓名", "年龄", "手机号", "住址");
    for (i = 0; i < con->sz; i++)
    {
        printf("%-20s\t%-20d\t%-20s\t%-20s\t\n", con->data[i].name, con->data[i].age, con->data[i].tel, con->data[i].adr);
    }
}

printf("%-20s\t%-20s\t%-20s\t%-20s\t\n", "姓名", "年龄", "手机号", "住址")中的%-20s\t%-20s\t%-20s\t%-20s\t\n是为了让打印联系人信息的时候更加直观,%-20s\t%-20s\t%-20s\t%-20s\t\n中的-是为了让其左对齐,把-去掉可以是右对齐。

8.删除指定联系人信息

void DelContact(struct Contact* con)//删除指定联系人信息函数
{
    assert(con);
    printf("请输入你要删除的联系人姓名:");
    /*char name[20];
    printf("请输入你要删除的联系人姓名:");
    scanf("%s", name);
    int i = 0;
    for (i = 0; i < con->sz; i++)
    {
        if (strcmp(con->data[i].name, name) == 0)
        {
            printf("删除成功!\n");
            con->sz--;
            break;
        }
    }*/
int i = Find(con);
if (i == -1)
{
    printf("未找到你要删除的联系人\n");
}
else
{
    int j = 0;
    for (j = i; j <= con->sz; j++)
    {
        con->data[j] = con->data[j + 1];
    }
    con->sz--;
    printf("删除成功!\n");
}
}

代码中注释部分可以在不调用 Find函数时删除联系人信息,在成功删除联系人信息后,要将存放联系人个数的变量进行修改。

9.修改联系人信息

void ModContact(struct Contact* con)//修改联系人信息
{
    assert(con);
    printf("请输入你要修改的联系人姓名:");
    /*char name[20];
    printf("请输入你要修改的联系人姓名:");
    scanf("%s", name);
    int i = 0;
    for (i = 0; i < con->sz; i++)
    {
        if (strcmp(con->data[i].name, name) == 0)
        {
            printf("找到要修改的联系人!\n");
            break;
        }
    }*/
    int i = Find(con);
    if (i == -1)
    {
        printf("未找到你要删除的联系人\n");
    }
    else
    {
        printf("请输入姓名:");
        scanf("%s", con->data[i].name);
        printf("请输入年龄:");
        scanf("%d", &(con->data[i].age));
        printf("请输入手机号:");
        scanf("%s", con->data[i].tel);
        printf("请输入住址:");
        scanf("%s", con->data[i].adr);
        printf("成功修改联系人信息!\n");
    }
}

10.查找指定联系人

void SearchContact(struct Contact* con)//查找指定联系人
{
    assert(con);//断言,con不能指向NULL
    printf("请输入你要查找的联系人姓名:");
    /*char name[20];
    printf("请输入你要查找的联系人姓名:");
    scanf("%s", name);
    int i = 0;
    for (i = 0; i < con->sz; i++)
    {
        if (strcmp(con->data[i].name, name) == 0)
        {
            break;
        }
    }*/
    int i = Find(con);
    if (i == -1)
    {
        printf("没有找到你要查找的联系人!\n");
    }
    else
    {
        printf("%-20s\t%-20s\t%-20s\t%-20s\t\n", "姓名", "年龄", "手机号", "住址");
        printf("%-20s\t%-20d\t%-20s\t%-20s\t\n", con->data[i].name, con->data[i].age, con->data[i].tel, con->data[i].adr);
    }
}

11.按照姓氏对联系人信息排序

int cmp_name(const void* e1, const void* e2)//qsort中的比较函数
{
    return strcmp(((struct PopInfo*)e1)->name, ((struct PopInfo*)e2)->name);//只能对字符及字符串排序,如果是数字,会出错
}
void Sort_name_Contact(struct Contact* con)//qsort函数排序
{
    qsort(con->data, con->sz, sizeof(struct PopInfo), cmp_name);
    printf("排序成功\n");//名字按照字母的ASCII码值从小到大排序
}

使用 qsort 函数对其进行排序。

12.清空所有联系人信息

void ClearContact(struct Contact* con)//清空所有联系人信息
{
	char str[10];
	while (1)
	{
		printf("确定清空通讯录吗?(yes/no):");
		scanf("%s", str);
		if (strcmp(str, "yes") == 0)
		{
			con->sz = 0;
			printf("已清空通讯录!\n");
			break;
		}
		else if (strcmp(str, "no") == 0)
		{
			printf("已取消!\n");
			break;
		}
		else
			printf("输入错误,请重新输入!\n");
	}
}

到此这篇关于C语言实现简易通讯录(静态版本)的代码分享的文章就介绍到这了,更多相关C语言静态通讯录内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

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

    目录 一.Contact.h文件 二.Contact.c文件 三.test.c文件 一.Contact.h文件 包含函数的声明 #pragma once #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <string.h> #include <stdlib.h> #include <assert.h> #define MAX 100 #define MAX_NAME 20 #defi

  • C语言开发实现通讯录管理系统

    本文实例为大家分享了C语言通讯录管理系统开发的具体代码,供大家参考,具体内容如下 程序介绍 通讯录管理系统主要是实现对联系人的增.删.查以及显示的基本操作.用户可以根据自己的需要在功能菜单中选择相应的操作,实现对联系人的快速管理. 操作流程 用户在编译完成后会产生一个系统的可执行文件,用户只要双击可执行文件就可以进入系统,进入系统的功能选择菜单,如图所示,用户根据自己的需要选择相应的操作. 代码 #include<stdio.h> #include<stdlib.h> #inclu

  • C语言通讯录管理系统完整代码

    本文实例为大家分享了C语言实现通讯录管理系统的具体代码,供大家参考,具体内容如下 设计内容: 设计一个通讯录管理系统,以实现以下功能:信息添加.查询.修改.删除.排序等功能. 设计要求: 1) 每条信息至包含 :姓名.电话.工作单位等信息2) 作为一个完整的系统,应具有友好的界面和较强的容错能力 预览: 代码: #include <stdio.h> #include <stdlib.h> #include <string.h> #include <windows.

  • 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语言实现简易通讯录

    本文实例为大家分享了C语言实现简易通讯录的具体代码,供大家参考,具体内容如下 功能描述: 1.存储联系人的相关信息,包括姓名.性别.电话号码.备注 2.可输出通讯录全部信息 3.清空通讯录的 4.用户交互界面 5.插入新联系人信息 6.查找联系人,包括"按姓名查找"和"按电话号查找"两种 7.删除联系人,包括"按姓名删除"和"按电话号删除"两种 8.按性别筛选联系人信息 在本次通讯录的编写代码中,涉及到了C高级和数据结构的一些

  • C语言实现简易通讯录功能

    本文实例为大家分享了C语言实现简易通讯录的具体代码,供大家参考,具体内容如下 这两天用C语言编写了一个简易版通讯录(学生信息管理) ,大致功能有添加信息,查看信息(自动按姓名排序,printf输出带颜色字体),查找信息(按姓名查找),删除信息(输入姓名删除相关信息),修改信息(输入修改人的名字,可选择修改其任意信息)和退出 . #include <stdio.h> #include <string.h> #include <stdlib.h> #define SIZE

  • C语言编程内存分配通讯录静态实现示例代码教程

    实现一个通讯录: 通讯录可以用来存储1000个人的信息,每个人的信息包括:姓名.性别.年龄.电话.住址 提供方法: 1. 添加联系人信息 2. 删除指定联系人信息 3. 查找指定联系人信息 4. 修改指定联系人信息 5. 显示所有联系人信息 6. 清空所有联系人 7. 以名字排序所有联系人 首先我们采用顺序表的方式来实现一个通讯录,顺序表就是一种静态的模式.但是呢,静态的方式存在着一些明显的弊端,比如说:(1)信息少了存在空间浪费现象,信息多了存在空间不足的现象:(2)无法对信息进行保存,没有实

  • C语言实现简易通讯录完整流程

    目标:通讯录可以存放1000个人信息,人的信息:性别名字年龄电话住址 菜单打印 1.增加联系人 2.删除联系人 3.查找联系人(修改) 4.名字排序联系人 5.展示 6.清空 分析: 首先通讯录存放联系人信息,还需知晓联系人个数,因此是个结构体类型 其次人的信息类型多,因此每个联系人也应为结构体类型 说明: 每个标题下展示的代码顺序:test.c (主函数测试运行)  ->  contact.h  (功能函数声明) ->  contact.c  (功能函数实现) 菜单打印: void menu

  • C语言实现简易通讯录实例

    目录 一.问题描述 二.功能介绍 二.实现流程 1.创建通讯录 2.创建源文件test.c 3.创建源文件contact.c 4.删除通讯录联系人信息 (DelContact函数实现) 5.查找通讯录联系人信息( SearchContact函数实现) 6.修改联系人信息(ModifyContact函数实现) 总结: 一.问题描述 用C语言来写一个简易的通讯录 二.功能介绍 通讯录1.通讯录中能够存放1000个人的信息每个人的信息:名字,年龄,性别,电话,地址2.增加人的信息3.删除人的信息4.修

  • Java语言实现二叉堆的打印代码分享

    二叉堆是一种特殊的堆,二叉堆是完全二元树(二叉树)或者是近似完全二元树(二叉树).二叉堆有两种:最大堆和最小堆.最大堆:父结点的键值总是大于或等于任何一个子节点的键值:最小堆:父结点的键值总是小于或等于任何一个子节点的键值. 打印二叉堆:利用层级关系 我这里是先将堆排序,然后在sort里执行了打印堆的方法printAsTree() public class MaxHeap<T extends Comparable<? super T>> { private T[] data; pr

  • 用C语言实现简易通讯录

    C语言实现一个通讯录,通讯录可以用来存储1000个人的信息,每个人的信息包括: 姓名.性别.年龄.电话.住址 **提供方法: 1. 添加联系人信息 2. 删除指定联系人信息 3. 查找指定联系人信息 4. 修改指定联系人信息 5. 显示所有联系人信息 6. 清空所有联系人 7. 以名字排序所有联系人** 思路分析: 首先我们可以分三个模块来解决这个问题,第一个模块我们需要一个头文件,这个头文件里可以包含一些相应信息,当实现文件和测试文件包含自己定义的头文件时便可以获得一些相关的信息.所以头文件里

  • C语言实现C++继承和多态的代码分享

    这个问题主要考察的是C和C++的区别,以及C++中继承和多态的概念. C和C++的区别 C语言是面向过程的语言,而C++是面向对象的过程. 什么是面向对象和面向过程? 面向过程就是分析解决问题的步骤,然后用函数把这些步骤一步一步的进行实现,在使用的时候进行一一调用就行了,注重的是对于过程的分析.面向对象则是把构成问题的事进行分成各个对象,建立对象的目的也不仅仅是完成这一个个步骤,而是描述各个问题在解决的过程中所发生的行为. 面向对象和面向过程的区别? 面向过程的设计方法采用函数来描述数据的操作,

  • C语言实现的统计素数并求和代码分享

    题目来源于PAT平台,此题又是费了一番脑子.题目要求输出给定区间内的素数个数并对他们求和.具体思路是利用循环判断素数,将结果传递给控制变量,由控制变量再来判断是否执行自增以及求和.当然这里必须要注意1既不是素数也不是合数. 下面是代码: 复制代码 代码如下: #include <stdio.h> int main () {  int a=0,b=0;  int n=0,sum=0;  int x=0,i=0;  scanf("%d %d",&a,&b);  

随机推荐