通讯录(一)

一、Contact.h

1.1.作用 :定义个人信息结构体 peoInfo 和常量。
1.2.代码:

代码如下:

#pragma once

#include<stdio.h>

#include<stdlib.h>

#include<string.h>

#include<assert.h>

#define MAX_NAME 20

#define MAX_PHONE 20

#define MAX_GENDER 10

#define MAX_ADDR 20

typedef struct peoInfo{

char name[MAX_NAME];

int age;

char gender[MAX_GENDER];

char addr[MAX_ADDR];

char phone[MAX_PHONE];

}peoInfo;

struct SeqList;

二、SeqList.h

2.1.作用 :定义顺序表结构,设置数据类型为 peoInfo,并将顺序表别名为 Contact
2.2.代码

代码如下:

#pragma once

#include"Contact.h"

typedef peoInfo SLDataType;

typedef struct SeqList {

SLDataType* a;

int size;

int capacity;

}SL;
typedef struct SeqList Contact; // 前置声明:告诉编译器有一个叫 SeqList 的结构体,因为 Contact.h 需要被 SeqList.h 包含,而 SeqList 的定义在 SeqList.h 中 为了避免循环依赖,这里只声明,具体定义在 SeqList.h

void SLCheckCapacity(SL* sl);

void SLprint(SL* sl);

void SLInit(SL* sl);

void SLPushFront(SL* sl, SLDataType x);

void SLPushBack(SL* sl, SLDataType x);

void SLInsert(SL* sl, int pos, SLDataType x);

void SLRemoveAll(SL* sl, SLDataType x);

void SLPopFront(SL* sl);

void SLPopBack(SL* sl);

void SLErase(SL* sl, int pos);

//查找元素

int SLFind(SL* sl, SLDataType x);

//修改指定位置的数据

void SLModify(SL* sl, int pos, SLDataType);

三、3-23.c

3.1.作用:实现顺序表的底层增删查改逻辑。
3.2.代码

代码如下:

// 打印单个

void PrintOne(const peoInfo* p) {

printf("%-10s %3d %-6s %-15s %-20s\n", p->name, p->age, p->gender, p->tel, p->addr);

}

// 打印所有

void SLPrint(SL* sl) {

assert(sl);

if (sl->size == 0) {

printf("通讯录为空。\n");

return;

}

printf("\n%-10s %-5s %-6s %-15s %-20s\n", "姓名", "年龄", "性别", "电话", "地址");

printf("------------------------------------------------------------\n");

for (int i = 0; i < sl->size; i++) {

PrintOne(&sl->a[i]);

}

printf("------------------------------------------------------------\n");

}

相关推荐
m0_6294947313 分钟前
LeetCode 热题 100-----17.缺失的第一个正数
数据结构·算法·leetcode
嵌入式-老费1 小时前
瑞芯微soc的学习和应用(题外话之esp32开发)
学习
hnjzsyjyj1 小时前
洛谷 P1443:马的遍历 ← BFS
数据结构·bfs
辰同学ovo2 小时前
从全局登录状态管理学习 Redux
前端·javascript·学习·react.js
ting94520002 小时前
告别无效学习:Scholé 如何用 AI 重构职场学习,让学习直接嵌入工作流
人工智能·学习·重构
xian_wwq2 小时前
【学习笔记】Harness到底是什么
笔记·学习·ai·harness
做时间的朋友。2 小时前
精准核酸检测
java·数据结构·算法
wuxinyan1232 小时前
大模型学习之路004:RAG 零基础入门教程(第一篇):基础理论与文档处理流水线
人工智能·学习·rag
冯诺依曼的锦鲤2 小时前
从零实现高并发内存池:TCMalloc 核心架构拆解
c++·学习·算法·架构
如君愿2 小时前
考研复习 Day28 | 习题--计算机网络第四章(网络层 中)、数据结构(树与二叉树 下)
数据结构·计算机网络·考研·课后习题·记录考研