第26讲:顺序表的应用(通讯录)

好,现在我们来做通讯录

上代码

文件1:SeqList.h

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
#include <string.h>
typedef struct SLcdatatype
{
	char name[10];
	int age;
	char sex[10];
	char tele[15];
}SLc;
//typedef int SLdatatype;//顺序表
typedef SLc SLdatatype;//通讯录
typedef struct SeqList
{
	SLdatatype* pa;//数组首元素地址
	int size;//元素个数
	int capacity;//数组容量
}SL;

//初始化顺序表
void initSeqList(SL* pSL);

//判断空间是否足够
void cheak(SL* psl1);

//扩容
void expandSL(SL* pSL);

//打印顺序表
void printSL(SL* pSL);

//后增
void backaddSL(SL* pSL);

//前增
void frontaddSL(SL* pSL);

//后删
void backdel(SL* pSL);

//前删
void frontdel(SL* pSL);

//指定位置插入
void posaddSL(SL* pSL,  int pos);

//指定位置删除
void posdelSL(SL* pSL, int pos);

//元素查找
void SLfind(SL* pSL);

//元素修改
void SLalter(SL* pSL, int pos);

//销毁
void SLdesdroy(SL* pSL);

文件二:SeqList.c

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include "Seqlist.h"
void initSeqList(SL* pSL)//初始化顺序表
{
	pSL->pa = NULL;
	pSL->size = 0;
	pSL->capacity = 0;
}

void cheak(SL* psl1)//检查空间是否足够
{
	if (psl1->size == psl1->capacity)
		expandSL(psl1);
}

void expandSL(SL* pSL)//扩容
{
	int newcapacity = pSL->capacity == 0 ? 4 : 2 * pSL->capacity;
	SLdatatype* pSLm = realloc(pSL->pa, (size_t)newcapacity * sizeof(*(pSL->pa)));
	if (pSLm == NULL)
	{
		perror("relloc");
		exit(1);
	}
	else
		pSL->pa = pSLm;
	pSL->capacity = newcapacity;
}

void printSL(SL* pSL)//打印顺序表
{
	assert(pSL);
	int i;
	printf("年龄 名字 性别 电话\n");
	for (i = 0; i < pSL->size; i++)
	{
		printf("%d ", (pSL->pa)[i].age);
		printf("%s ", (pSL->pa)[i].name);
		printf("%s ", (pSL->pa)[i].sex);
		printf("%s \n", (pSL->pa)[i].tele);
	}
}

void backaddSL(SL* pSL)//后增
{
	assert(pSL);
	cheak(pSL);
	scanf("%d", &(pSL->pa)[pSL->size].age);
	scanf("%s", (pSL->pa)[pSL->size].name);
	scanf("%s", (pSL->pa)[pSL->size].sex);
	scanf("%s", (pSL->pa)[pSL->size].tele);
	pSL->size++;
}

void frontaddSL(SL* pSL)//前增
{
	assert(pSL);
	cheak(pSL);
	int i;
	for (i = 0; i < pSL->size; i++)
	{
		(pSL->pa)[pSL->size - i].age = (pSL->pa)[pSL->size - i - 1].age;
		strcpy((pSL->pa)[pSL->size - i].name, (pSL->pa)[pSL->size - i - 1].name);
		strcpy((pSL->pa)[pSL->size - i].sex, (pSL->pa)[pSL->size - i - 1].sex);
		strcpy((pSL->pa)[pSL->size - i].tele, (pSL->pa)[pSL->size - i - 1].tele);
	}
	scanf("%d", &(pSL->pa)->age);
	scanf("%s", (pSL->pa)->name);
	scanf("%s", (pSL->pa)->sex);
	scanf("%s", (pSL->pa)->tele);
	pSL->size++;
}

void backdel(SL* pSL)//后删
{
	assert(pSL != NULL);
	assert(pSL->size > 0);
	pSL->size--;
}

void frontdel(SL* pSL)//前删
{
	assert(pSL != NULL);
	assert(pSL->size > 0);
	int i;
	for (i = 0; i < pSL->size - 1; i++)
	{
		(pSL->pa)[i].age = (pSL->pa)[i + 1].age;
		strcpy(pSL->pa[i].name, pSL->pa[i + 1].name);
		strcpy(pSL->pa[i].sex, pSL->pa[i + 1].sex);
		strcpy(pSL->pa[i].tele, pSL->pa[i + 1].tele);
	}
	pSL->size--;
}

void posaddSL(SL* pSL,  int pos)//指定位置插入
{
	assert(pSL);
	int i = 0;
	for (i = 0; i < pSL->size - pos + 1; i++)
	{
		pSL->pa[pSL->size - i].age = pSL->pa[pSL->size - i - 1].age;
		strcpy(pSL->pa[pSL->size - i].name, pSL->pa[pSL->size - i - 1].name);
		strcpy(pSL->pa[pSL->size - i].sex, pSL->pa[pSL->size - i - 1].sex);
		strcpy(pSL->pa[pSL->size - i].tele, pSL->pa[pSL->size - i - 1].tele);
	}
	scanf("%d", &(pSL->pa)[pos-1].age);
	scanf("%s", (pSL->pa)[pos - 1].name);
	scanf("%s", (pSL->pa)[pos - 1].sex);
	scanf("%s", (pSL->pa)[pos - 1].tele);
	pSL->size++;
}

void posdelSL(SL* pSL, int pos)//指定位置删除
{
	assert(pSL);
	int i = 0;
	for (i = 0; i < pSL->size - pos + 1; i++)
	{
		pSL->pa[pos - 1 + i].age = pSL->pa[pos + i].age;
		strcpy(pSL->pa[pos - 1 + i].name, pSL->pa[pos + i].name);
		strcpy(pSL->pa[pos - 1 + i].sex, pSL->pa[pos + i].sex);
		strcpy(pSL->pa[pos - 1 + i].tele, pSL->pa[pos + i].tele);
	}
	pSL->size--;
}

void SLfind(SL* pSL)//元素查找
{
	int i = 0, flag = 1;
	char arr[10];
	scanf("%s", arr);
	for (i = 0; i < pSL->size; i++)
	{
		if (strcmp(pSL->pa[i].name, arr) == 0)
		{
			printf("元素下标为%d\n", i);
			flag = 0;
		}
	}
	if (flag)
		puts("没有该元素");
}

void SLalter(SL* pSL, int pos)//元素修改
{
	scanf("%d", &pSL->pa[pos - 1].age);
	scanf("%s", &pSL->pa[pos - 1].name);
	scanf("%s", &pSL->pa[pos - 1].sex);
	scanf("%s", &pSL->pa[pos - 1].tele);
}

void SLdesdroy(SL* pSL)//销毁
{
	assert(pSL);
	if (pSL->pa != NULL)
	{
		free(pSL->pa);
		pSL->pa = NULL;
	}
	pSL->size = 0;
	pSL->capacity = 0;
}

文件三:contact.c

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include "SeqList.h"
int main()
{
	SL sl;
	printf("年龄 名字 性别 电话\n");
	initSeqList(&sl);
	backaddSL(&sl);
	backaddSL(&sl);
	backaddSL(&sl);
	backaddSL(&sl);
	backaddSL(&sl);
	//frontaddSL(&sl);
	//frontaddSL(&sl);
	//frontaddSL(&sl);
	//printSL(&sl);
	//backdel(&sl);
	//printSL(&sl);
	//frontdel(&sl);
	printSL(&sl);
	SLfind(&sl);
	//SLdesdroy(&sl);
	return 0;
}

我们讲讲通讯录和上一节顺序表的区别以及本代码的构思

首先,通讯录就是顺序表

本来,pa指向的是一个变量,现在让它指向结构体,使其储存的数据多样化

我们可以通过对pa下标访问,访问到每一个结构体,然后用 . 进行结构体成员访问

基本思路:略(第26讲有详解)

相关推荐
爱吃喵的鲤鱼2 分钟前
linux进程的状态之环境变量
linux·运维·服务器·开发语言·c++
DARLING Zero two♡28 分钟前
关于我、重生到500年前凭借C语言改变世界科技vlog.16——万字详解指针概念及技巧
c语言·开发语言·科技
7年老菜鸡29 分钟前
策略模式(C++)三分钟读懂
c++·qt·策略模式
Gu Gu Study31 分钟前
【用Java学习数据结构系列】泛型上界与通配符上界
java·开发语言
Ni-Guvara38 分钟前
函数对象笔记
c++·算法
似霰42 分钟前
安卓智能指针sp、wp、RefBase浅析
android·c++·binder
芊寻(嵌入式)1 小时前
C转C++学习笔记--基础知识摘录总结
开发语言·c++·笔记·学习
獨枭1 小时前
C++ 项目中使用 .dll 和 .def 文件的操作指南
c++
霁月风1 小时前
设计模式——观察者模式
c++·观察者模式·设计模式
橘色的喵1 小时前
C++编程:避免因编译优化引发的多线程死锁问题
c++·多线程·memory·死锁·内存屏障·内存栅栏·memory barrier