进阶-数据结构部分:1、数据结构入门

news2025/5/20 19:05:21

飞书文档https://x509p6c8to.feishu.cn/wiki/HRLkwznHiiOgZqkqhLrcZNqVnLd

一、存储结构

顺序存储

链式存储

二、常用数据结构

2.1、栈

先进后出

场景:

后退/前进功能:网页浏览器中的后退和前进按钮可以使用栈来实现。在浏览网页时,每次访问一个新页面时,当前页面的信息将被推入栈中。当用户点击后退按钮时,程序将从栈中弹出最近的访问页面,并显示上一个页面。


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

#define MAX_STACK_SIZE 100

typedef struct {
    char url[MAX_STACK_SIZE];
} StackItem;

typedef struct {
    StackItem items[MAX_STACK_SIZE];
    int top;
} Stack;

void initStack(Stack *stack) {
    stack->top = -1;
}

int isStackEmpty(Stack *stack) {
    return stack->top == -1;
}

int isStackFull(Stack *stack) {
    return stack->top == MAX_STACK_SIZE - 1;
}

void push(Stack *stack, char *url) {
    if (isStackFull(stack)) {
        printf("Stack overflow!\n");
        return;
    }
    stack->top++;
    strcpy(stack->items[stack->top].url, url);
}

char* pop(Stack *stack) {
    if (isStackEmpty(stack)) {
        printf("Stack underflow!\n");
        return NULL;
    }
    char *url = stack->items[stack->top].url;
    stack->top--;
    return url;
}

int main() {
    char inputurl[MAX_STACK_SIZE];
    int choice;
    Stack stack;
    initStack(&stack);

    while (1)
    {
        printf("------》1:入栈\n");
        printf("------》2:出栈\n");
        scanf("%d",&choice);
        switch (choice)
        {
        case 1:
            printf("请输入入栈内容:");
            scanf("%s",inputurl);
            push(&stack,inputurl);
            printf("入栈成功\n");
            break;
        case 2:
            if (!isStackEmpty(&stack)) {
                char *url = pop(&stack);
                printf("出栈:%s\n", url);
            }else{
                printf("已没有数据\n");
            }
            break;
        default:
            printf("无效操作\n");
            break;
        }
    }
    return 0;
}

2.2、队列

场景:

编写代码,实现演唱会购票用户(id、座位区域(A、B、C))购票与出票。

分析:

按购票顺序先后处理,先购票先出票

#include <stdio.h>

#define MAX_AREA_SIZE 10
#define MAX_QUEUE_SIZE 5

typedef struct {
    int id;
    char area[MAX_AREA_SIZE];
} User;

typedef struct {
    User data[MAX_QUEUE_SIZE];
    int front; //队列头位置
    int rear;  //队列尾位置
} Queue;

/**
 * @brief 初始化队列
 * 初始化时,由于队列为空,队列头和尾位置都在0
 * @param q
 */
void initQueue(Queue *q) {
    q->front = q->rear = 0;
}

/**
 * @brief 判断队列是否为空
 * 当队列头位置和尾位置相同时,队列为空
 * @param q
 * @return int
 */
int isQueueEmpty(Queue *q) {
    return q->front == q->rear;
}

/**
 * @brief 判断队列是否满
 * 当队列尾位置+1等于队列头位置时,队列满(队列尾位置追上头位置)
 * @param q
 * @return int
 */
int isQueueFull(Queue *q) {
    return (q->rear + 1) % MAX_QUEUE_SIZE == q->front;
}

/**
 * @brief 入队
 * 先判断队列是否满,然后存储数据到队列尾位置,队列尾位置+1
 * @param q
 * @param s
 * @return int
 */
int enqueue(Queue *q, User *s) {
    if (isQueueFull(q)) {
        return 0;
    }
   printf("id=%d, area=%s ", s->id, s->area);
    q->data[q->rear] = *s;
    q->rear = (q->rear + 1) % MAX_QUEUE_SIZE;
    return 1;
}
/**
 * @brief 出队
 * 先判断队列是否空,然后读取队列头的数据,队列头位置+1
 * @param q
 * @param s
 * @return int
 */
int dequeue(Queue *q, User *s) {
    if (isQueueEmpty(q)) {
        return 0;
    }
    *s = q->data[q->front];
    printf("id=%d, area=%s\n", s->id, s->area);
    q->front = (q->front + 1) % MAX_QUEUE_SIZE;
    return 1;
}

int main() {
    int id = 0;
    User user;
    int choice;
    Queue q;
    initQueue(&q);

    while (1)
    {
        printf("------》1:顾客购票\n");
        printf("------》2:工作人员出票\n");
        scanf("%d",&choice);
        switch (choice)
        {
        case 1:
            printf("请输入购票区域:");
            user.id = id ++;
            scanf("%s",user.area);
            if(enqueue(&q, &user) == 1)
                printf("支付成功,等待工作人员处理\n");
            else
                printf("支付失败,当前无票\n");
            break;
        case 2:
            printf("出票:");
            User s;
            if (!dequeue(&q, &s)) {
                printf("已没有购票需要处理\n");
            }
            break;
        default:
            printf("无效操作\n");
            break;
        }
    }
    return 0;
}

2.3、链表

场景:实现一个用户信息管理系统,支持插入、查找、删除

分析:


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

// 定义用户结构体
typedef struct User {
    char name[50];
    int age;
    struct User *next;
} User;

// 初始化链表头节点
User *head = NULL;

// 插入用户信息
void insertUser() {
    User *newUser = (User *) malloc(sizeof(User));
    printf("请输入用户名:");
    scanf("%s", newUser->name);
    printf("请输入年龄:");
    scanf("%d", &newUser->age);
    newUser->next = NULL;

    if (head == NULL) {
        head = newUser;
    } else {
        User *temp = head;
        while (temp->next != NULL) {
            temp = temp->next;
        }
        temp->next = newUser;
    }

    printf("用户信息插入成功!\n");
}

// 删除用户信息
void deleteUser() {
    if (head == NULL) {
        printf("链表为空,无法删除用户信息!\n");
        return;
    }

    char name[50];
    printf("请输入要删除的用户名:");
    scanf("%s", name);

    User *temp = head;
    User *prev = NULL;
    while (temp != NULL && strcmp(temp->name, name) != 0) {
        prev = temp;
        temp = temp->next;
    }

    if (temp == NULL) {
        printf("未找到要删除的用户信息!\n");
        return;
    }

    if (prev == NULL) {
        head = temp->next;
    } else {
        prev->next = temp->next;
    }

    free(temp);
    printf("用户信息删除成功!\n");
}

// 查找用户信息
void findUser() {
    if (head == NULL) {
        printf("链表为空,无法查找用户信息!\n");
        return;
    }

    char name[50];
    printf("请输入要查找的用户名:");
    scanf("%s", name);

    User *temp = head;
    while (temp != NULL && strcmp(temp->name, name) != 0) {
        temp = temp->next;
    }

    if (temp == NULL) {
        printf("未找到要查找的用户信息!\n");
    } else {
        printf("用户名:%s,年龄:%d\n", temp->name, temp->age);
    }
}

int main() {
    int choice;

    while (1) {
        printf("请选择要执行的操作:\n");
        printf("1. 插入用户信息\n");
        printf("2. 删除用户信息\n");
        printf("3. 查找用户信息\n");
        printf("4. 退出程序\n");
        printf("请输入操作编号:");
        scanf("%d", &choice);

        switch (choice) {
            case 1:
                insertUser();
                break;
            case 2:
                deleteUser();
                break;
            case 3:
                findUser();
                break;
            case 4:
                exit(0);
            default:
                printf("输入的操作编号有误,请重新输入!\n");
                break;
        }
    }

    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2380184.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

React 19中useContext不需要Provider了。

文章目录 前言一、React 19中useContext移除了Provider&#xff1f;二、使用步骤总结 前言 在 React 19 中&#xff0c;useContext 的使用方式有所更新。开发者现在可以直接使用 作为提供者&#xff0c;而不再需要使用 <Context.Provider>。这一变化简化了代码结构&…

Json schema校验json字符串(networknt/json-schema-validator库)

学习链接 json-schema官网 - 英文 jsonschemavalidator 可在线校验网站 networknt的json-schema-validator github地址 networknt的json-schema-validator 个人gitee地址 - 里面有md文档说明和代码示例 JSON Schema 入门指南&#xff1a;如何定义和验证 JSON 数据结构 JS…

交易所开发:构建功能完备的金融基础设施全流程指南

交易所开发&#xff1a;构建功能完备的金融基础设施全流程指南 ——从技术架构到合规安全的系统性解决方案 一、开发流程&#xff1a;从需求分析到运维优化 开发一款功能完备的交易所需要遵循全生命周期管理理念&#xff0c;涵盖市场定位、技术实现、安全防护和持续迭代四大阶…

Axure疑难杂症:统计分析页面引入Echarts示例动态效果

亲爱的小伙伴,在您浏览之前,烦请关注一下,在此深表感谢! Axure产品经理精品视频课已登录CSDN可点击学习https://edu.csdn.net/course/detail/40420 课程主题:统计分析页面引入Echarts示例动态效果 主要内容:echart示例引入、大小调整、数据导入 应用场景:统计分析页面…

展锐Android14及更新版本split_build编译方法

更改split_build.py文件内容后按照下面方法编译&#xff1a; zip -r sys/vendor/sprd/release/split_build.zip sys/vendor/sprd/release/split_build/ rm -r sys/vendor/sprd/release/split_build/ cp -r vnd/vendor/sprd/release/split_build/ sys/vendor/sprd/release/cd s…

青少年ctf平台应急响应-应急响应2

题目&#xff1a; 当前服务器被创建了一个新的用户&#xff0c;请提交新用户的用户名&#xff0c;得到的结果 ssh rootchallenge.qsnctf.com -p 30327 这个命令用于通过 SSH 协议连接到指定的远程服务器。具体解释如下&#xff1a; ssh&#xff1a;这是在 Unix-like 系统中…

k8s监控方案实践补充(二):使用kube-state-metrics获取资源状态指标

k8s监控方案实践补充&#xff08;二&#xff09;&#xff1a;使用kube-state-metrics获取资源状态指标 文章目录 k8s监控方案实践补充&#xff08;二&#xff09;&#xff1a;使用kube-state-metrics获取资源状态指标一、Metrics Server简介二、kube-state-metrics实战部署1. 创…

基于SpringBoot的小型民营加油站管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…

技术架构缺乏灵活性,如何应对变化需求?

技术架构缺乏灵活性会导致企业在面临市场变化、用户需求演化或新技术出现时难以及时响应&#xff0c;直接影响产品更新速度与竞争力。要有效应对变化需求&#xff0c;需要从引入模块化架构设计、推动微服务拆分、加强架构治理与决策机制、构建中台与平台化能力等方面系统推进。…

【AI时代】Java程序员大模型应用开发详细教程(上)

目录 一、大模型介绍 1. 大模型介绍 1.1 什么是大模型 1.2 技术储备 1.3 大模型的分类 2. 入门案例 3.Token的介绍 二、提示词工程 1. 好玩的提示词案例 1.1 翻译软件 1.2 让Deepseek绘画 1.3 生成数据 1.4 代码生成 2. 提示词介绍 3. Prompt Engineering最佳实…

虚拟网络编辑器

vmnet1 仅主机模式 hostonly 功能&#xff1a;虚拟机只能和宿主机通过vmnet1通信&#xff0c;不可连接其他网络&#xff08;包括互联网&#xff09; vmnet8 地址转换模式 NAT 功能&#xff1a;虚拟机可以和宿主通过vmnet8通信&#xff0c;并且可以连接其他网络&#xff0c;但是…

第31讲 循环缓冲区与命令解析

串口在持续接收数据时容易发生数据黏包&#xff08;先接收的数据尚未被处理&#xff0c;后面的数据已经将内存覆盖&#xff09;的情况&#xff0c;循环缓冲区的本质就是将串口接受到的数据马上拷贝到另外一块内存之中。为了避免新来的数据覆盖掉尚未处理的数据&#xff0c;一方…

数据结构(十)——排序

一、选择排序 1.简单选择排序 基本思想&#xff1a;假设排序表为[1,…,n]&#xff0c;第i趟排序即从[i,…,n]中选择关键字最小的元素与L[i]交换 eg&#xff1a;给定关键字序列{87&#xff0c;45&#xff0c;78&#xff0c;32&#xff0c;17&#xff0c;65&#xff0c;53&…

美蛋工具箱:一站式解决图片、视频、音频和文档处理需求的聚合神器

先放下载链接:夸克网盘下载 宝子们&#xff0c;今天不啰嗦&#xff0c;直接给大家安利一款超好用的聚合工具&#xff0c;有需要的小伙伴赶紧码住&#xff01; 今天要介绍的这款工具叫美蛋工具箱&#xff0c;它是一款聚合类工具。这个软件是绿色版的&#xff0c;聚合了图片工具…

python打卡day16

NumPy 数组基础 因为前天说了shap&#xff0c;这里涉及到数据形状尺寸问题&#xff0c;所以需要在这一节说清楚&#xff0c;后续的神经网络我们将要和他天天打交道。 知识点&#xff1a; numpy数组的创建&#xff1a;简单创建、随机创建、遍历、运算numpy数组的索引&#xff1a…

Redis 学习笔记 5:分布式锁

Redis 学习笔记 5&#xff1a;分布式锁 在前文中学习了如何基于 Redis 创建一个简单的分布式锁。虽然在大多数情况下这个锁已经可以满足需要&#xff0c;但其依然存在以下缺陷&#xff1a; 事实上一般而言&#xff0c;我们可以直接使用 Redisson 提供的分布式锁而非自己创建。…

游戏开发实战(一):Python复刻「崩坏星穹铁道」嗷呜嗷呜事务所---源码级解析该小游戏背后的算法与设计模式【纯原创】

文章目录 奇美拉项目游戏规则奇美拉(Chimeras)档案领队成员 结果展示&#xff1a; 奇美拉项目 由于项目工程较大&#xff0c;并且我打算把我的思考过程和实现过程中踩过的坑都分享一下&#xff0c;因此会分3-4篇博文详细讲解本项目。本文首先介绍下游戏规则并给出奇美拉档案。…

02- 浏览器运行原理

文章目录 1. 网页的解析过程浏览器内核 2. 浏览器渲染流程2.1 解析html2.2 生成css规则2.3 构建render tree2.4 布局(Layout)2.5 绘制(Paint) 3. 回流和重绘3.1 回流reflow&#xff08;1&#xff09;理解&#xff1a;&#xff08;2&#xff09;出现情况 3.2 重绘repaint&#x…

移除链表元素数据结构oj题(力扣题206)

目录 题目描述&#xff1a; 题目解读&#xff08;分析&#xff09; 解决代码 题目描述&#xff1a; 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链表中所有满足 Node.val val 的节点&#xff0c;并返回 新的头节点 。 题目解读&#xff08;分析&#…

OpenTelemetry 从入门到精通

快速入门 OpenTelemetry 是一个可观测性框架和工具包&#xff0c; 旨在创建和管理遥测数据&#xff0c;如链路、 指标和日志。 重要的是&#xff0c;OpenTelemetry 是供应商和工具无关的&#xff0c;这意味着它可以与各种可观测性后端一起使用&#xff0c; 包括 Jaeger 和 Pro…