单链表实现通讯录

不过多赘述了

顺序表的增删查改-CSDN博客https://blog.csdn.net/bkmoo/article/details/137566495?spm=1001.2014.3001.5502

使用顺序表实现通讯录-CSDN博客https://blog.csdn.net/bkmoo/article/details/137676561?spm=1001.2014.3001.5502这里没有使用文件操作只是简单的使用单链表创造一次性的单链表,主要体现是单链表的使用。

首先创建头文件,用来放置函数的声明。contact.h文件,函数的功能分别是创建节点(初始化),通讯录的增删查改和展示通讯录,销毁通讯录。

contact.h代码

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#pragma once
#define NAME_MAX 100
#define SEX_MAX 4
#define TEL_MAX 11
#define ADDR_MAX 100

//前置声明
typedef struct SListNode contact;

//用户数据
typedef struct PersonInfo
{
    char name[NAME_MAX];
    char sex[SEX_MAX];
    int age;
    char tel[TEL_MAX];
    char addr[ADDR_MAX];
}PeoInfo;

struct SListNode
{
    PeoInfo* pival;
    contact* next;
};




//创建节点//初始化通讯录
contact* newNode();
//添加通讯录数据
void AddContact(contact* con);
//删除通讯录数据
void DelContact(contact* con);
//展示通讯录数据
void ShowContact(contact* con);
//查找通讯录数据
void FindContact(contact* con);
//修改通讯录数据
void ModifyContact(contact** con);
//销毁通讯录数据
void DestroyContact(contact** con);

接着创建contact.c文件放置函数功能实现的代码

创建节点,包含对节点初始化contact* newNode()

contact* newNode()

{

contact* Node = (contact*)malloc(sizeof(contact));

Node->pival = (PeoInfo*)malloc(sizeof(PeoInfo));

Node->next = NULL;

return Node;

}

要记住使用结构体指针储存数据时要分配内存空间,否则就会报错

增加联系人void AddContact(contact* con)

//添加
void AddContact(contact* con)
{
//PeoInfo arr;
contact* pcur = con;
contact* newnode = newNode();
contactadd(newnode);
while (pcur->next != NULL)
{
pcur = pcur->next;
}
pcur->next = newnode; // 在连接时不要用pcur直接等于这里的pcur是临时值,临时值中保存的内容才是需要操作的地址
//因此要先解引用后链接(->相当于一层解引用)
}

先创建节点初始化,输入数据后。得到一个完整的节点后进行操作,不然就很乱,这样更容易操作。

在连接时不要用pcur直接等于这里的pcur是临时值,临时值中保存的内容才是需要操作的地址,因此要先解引用后链接(->相当于一层解引用)

这里使用到的contactadd函数是输入联系人内容的操作contactadd

void contactadd(contact* con)

{

//PeoInfo* ret = (PeoInfo*)malloc(sizeof(PeoInfo));

printf("请输入联系人姓名:\n");

scanf("%s", con->pival->name);

printf("请输入联系人性别:\n");

scanf("%s", con->pival->sex);

printf("请输入联系人年龄:\n");

scanf("%d", &(con->pival->age));

printf("请输入联系人电话\n");

scanf("%s", con->pival->tel);

printf("请输入联系人地址:\n");

scanf("%s", con->pival->addr);

}

查找操作void FindContact(contact* con)

实现查找操作要先创建一个函数用来寻找节点,方便后续的删除修改操作。一般查找联系人是以人名来找,因此还要一个name数组。

查找节点的函数contact* findContact(contact* con, char a[])

contact* findContact(contact* con, char a[])

{

con = con->next;

while (con != NULL)

{

if (strcmp(con->pival->name, a) == 0)

{

return con;

}

con = con->next;

}

return NULL;

}
//查找

void FindContact(contact* con)

{

printf("请输入要查找的联系人名字:\n");

char a[NAME_MAX];

scanf("%s", a);

contact* ret = findContact(con, a);

if (ret)

{

printf("找到了\n");

}

else

{

printf("没找到\n");

}

}

删除联系人

删除操作需要先找到要删除的联系人使用contact* findContact(contact* con, char a[])函数

//删除

void DelContact(contact* con)

{

contact* pcur = con;

printf("请输入要删除的联系人名字:\n");

char a[NAME_MAX];

scanf("%s", a);

contact* ret = findContact(con, a);

if (ret)

{

while (pcur->next != ret)

{

pcur = pcur->next;

}

pcur->next = ret->next;

free(ret);

ret = NULL;

}

else

{

printf("查无此人\n");

}

}

修改联系人数据void ModifyContact(contact** con)

需要先找到需要修改的联系人

//修改

void ModifyContact(contact** con)

{

contact* pcur = con;

printf("请输入要修改的联系人名字:\n");

char a[NAME_MAX];

scanf("%s", a);

contact* ret = findContact(con, a);

if (ret)

{

contactadd(ret);

}

else

{

printf("查无此人\n");

}

}

展示操作void ShowContact(contact* con)

//展示

void ShowContact(contact* con)

{

con = con->next;

while (con != NULL)

{

printf("姓名:%s ", con->pival->name);

printf("性别:%s", con->pival->sex);

printf("年龄:%d", con->pival->age);

printf("电话:%s", con->pival->tel);

printf("地址:%s", con->pival->addr);

printf("\n");

con = con->next;

}

}

最后销毁链表

//销毁

void DestroyContact(contact** con)

{

contact* pcur = *con;

contact* perv = pcur->next;

while (pcur)

{

free(pcur->pival);

free(pcur);

pcur = perv;

if (pcur == NULL)

{

break;

}

perv = perv->next;

}

}

contact.c代码

#include "contact.h"

void prin(contact* con)
{
	con = con->next;
	while (con != NULL)
	{
		printf("姓名:%s ", con->pival->name);
		printf("性别:%s", con->pival->sex);
		printf("年龄:%d", con->pival->age);
		printf("电话:%s", con->pival->tel);
		printf("地址:%s", con->pival->addr);
		printf("\n");
		con = con->next;
	}
}



contact* newNode()
{
	contact* Node = (contact*)malloc(sizeof(contact));
	Node->pival = (PeoInfo*)malloc(sizeof(PeoInfo));
	Node->next = NULL;
	return Node;
}

//联系人数据
void contactadd(contact* con)
{
	//PeoInfo* ret = (PeoInfo*)malloc(sizeof(PeoInfo));
	printf("请输入联系人姓名:\n");
	scanf("%s", con->pival->name);

	printf("请输入联系人性别:\n");
	scanf("%s", con->pival->sex); 

	printf("请输入联系人年龄:\n");
	scanf("%d", &(con->pival->age));

	printf("请输入联系人电话\n");
	scanf("%s", con->pival->tel);

	printf("请输入联系人地址:\n");
	scanf("%s", con->pival->addr);
}
//添加
void AddContact(contact* con)
{
	//PeoInfo arr;
	contact* pcur = con;
	contact* newnode = newNode();
	contactadd(newnode);//先创建,初始化,输入数据后。即一个完整的节点后进行操作,不然就很乱
	while (pcur->next != NULL)
	{
		pcur = pcur->next;
	}
	pcur->next = newnode; // 在连接时不要用pcur直接等于这里的pcur是临时值,临时值中保存的内容才是需要操作的地址
	//因此要先解引用后链接(->相当于一层解引用)
 }

contact* findContact(contact* con, char a[])
{

	con = con->next;
	while (con != NULL)
	{
		if (strcmp(con->pival->name, a) == 0)
		{
			return con;
		}
		con = con->next;
	}
	return NULL;
}
//查找
void FindContact(contact* con)
{
	printf("请输入要查找的联系人名字:\n");
	char a[NAME_MAX];
	scanf("%s", a);

	contact* ret = findContact(con, a);
	if (ret)
	{
		printf("找到了\n");
	}
	else
	{
		printf("没找到\n");
	}

}
//删除
void DelContact(contact* con)
{
	contact* pcur = con;

	printf("请输入要删除的联系人名字:\n");
	char a[NAME_MAX];
	scanf("%s", a);
	contact* ret = findContact(con, a);
	if (ret)
	{
		while (pcur->next != ret)
		{
			pcur = pcur->next;
		}
		pcur->next = ret->next;
		free(ret);
		ret = NULL;
	}
	else
	{
		printf("查无此人\n");
	}
}



//修改
void ModifyContact(contact** con)
{
	contact* pcur = con;

	printf("请输入要修改的联系人名字:\n");
	char a[NAME_MAX];
	scanf("%s", a);

	contact* ret = findContact(con, a);

	if (ret)
	{
		contactadd(ret);
	}
	else
	{
		printf("查无此人\n");
	}
}

//展示
void ShowContact(contact* con)
{
	con = con->next;
	while (con != NULL)
	{
		printf("姓名:%s ", con->pival->name);
		printf("性别:%s", con->pival->sex);
		printf("年龄:%d", con->pival->age);
		printf("电话:%s", con->pival->tel);
		printf("地址:%s", con->pival->addr);
		printf("\n");
		con = con->next;
	}
}

//销毁
void DestroyContact(contact** con)
{
	contact* pcur = *con;
	contact* perv = pcur->next;
	while (pcur)
	{
		free(pcur->pival);
		free(pcur);
		pcur = perv;
		if (pcur == NULL)
		{
			break;
		}
		perv = perv->next;
	}
}
相关推荐
未知陨落几秒前
数据结构——二叉搜索树
开发语言·数据结构·c++·二叉搜索树
一丝晨光41 分钟前
gcc 1.c和g++ 1.c编译阶段有什么区别?如何知道g++编译默认会定义_GNU_SOURCE?
c语言·开发语言·c++·gnu·clang·gcc·g++
CyberMuse2 小时前
表的数据结构和常见操作
数据结构
爱吃生蚝的于勒2 小时前
C语言最简单的扫雷实现(解析加原码)
c语言·开发语言·学习·计算机网络·算法·游戏程序·关卡设计
小五Z2 小时前
MySql--增删改查表设计总结
数据结构·数据库·mysql
秋说3 小时前
【数据结构 | C++】整型关键字的平方探测法散列
数据结构·c++·算法
weixin_478689763 小时前
【回溯法】——组合总数
数据结构·python·算法
hutaotaotao5 小时前
c语言用户不同命令调用不同函数实现
c语言·开发语言
lb36363636365 小时前
介绍一下位操作符(c基础)
c语言·知识点
shinelord明6 小时前
【再谈设计模式】建造者模式~对象构建的指挥家
开发语言·数据结构·设计模式