news 2026/6/23 10:23:20

线性表之链式栈

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
线性表之链式栈
  • 插入操作和删除操作均在链表头部进行,链表尾部就是栈底,栈顶指针就是头指针
  • 不需要预先分配固定大小
  • 动态增长和收缩

typedefintdata_t;/*定义栈中数据元素数据类型*/typedefstructnode_t{data_tdata;/*数据域*/structnode_t*next;/*链接指针域*/}linkstack_t;/*链栈类型定义*/
  • 功能实现
#include<stdio.h>#include<stdlib.h>#include"linkstack.h"linkstackstack_create(){linkstack s;s=(linkstack)malloc(sizeof(listnode));if(s==NULL){printf("malloc failed\n");returnNULL;}s->data=0;s->next=NULL;returns;}intstack_push(linkstack s,data_tvalue){linkstack p;if(s==NULL){printf("s is NULL\n");return-1;}p=(linkstack)malloc(sizeof(listnode));if(p==NULL){printf("malloc failed\n");return-1;}p->data=value;//p->next = NULL;p->next=s->next;s->next=p;return0;}data_tstack_pop(linkstack s){linkstack p;data_tt;p=s->next;s->next=p->next;t=p->data;free(p);p=NULL;returnt;}intstack_empty(linkstack s){if(s==NULL){printf("s is NULL\n");return-1;}return(s->next==NULL?1:0);}data_tstack_top(linkstack s){return(s->next->data);}linkstackstack_free(linkstack s){linkstack p;if(s==NULL){printf("s is NULL\n");returnNULL;}while(s!=NULL){p=s;s=s->next;printf("free:%d\n",p->data);free(p);}returnNULL;}
  • 头文件
typedefintdata_t;typedefstructnode{data_tdata;structnode*next;}listnode,*linkstack;linkstackstack_create();intstack_push(linkstack s,data_tvalue);data_tstack_pop(linkstack s);intstack_empty(linkstack s);data_tstack_top(linkstack s);linkstackstack_free(linkstack s);
  • 测试文件
#include<stdio.h>#include<stdlib.h>#include"linkstack.h"intmain(intargc,constchar*argv[]){linkstack s;s=stack_create();if(s==NULL)return-1;stack_push(s,10);stack_push(s,20);stack_push(s,30);stack_push(s,40);while(!stack_empty(s)){printf("pop:%d\n",stack_pop(s));}s=stack_free(s);return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 1:54:57

云手机 实体手机的云端延伸

云手机可视为实体手机的云端延伸。它基于云计算技术和虚拟化技术&#xff0c;在云端服务器上虚拟出带有原生安卓等操作系统的手机实例&#xff0c;通过网络与实体设备连接&#xff0c;用户可通过实体手机、平板或电脑等设备远程操控云手机&#xff0c;实现诸如运行应用、游戏等…

作者头像 李华
网站建设 2026/6/23 4:13:33

交换机和网卡的 PFC 机制工作原理与实例解析

PFC&#xff08;Priority-based Flow Control&#xff0c;基于优先级的流控&#xff09; 是数据中心以太网&#xff08;如 RoCE v2、DCB&#xff09;的核心技术&#xff0c;属于链路层&#xff08;Layer 2&#xff09;流量控制机制。其核心目标是解决拥塞导致的丢包问题—— 通…

作者头像 李华
网站建设 2026/6/22 19:58:33

UI自动化测试常见面试题

1、什么是UI自动化测试&#xff1f; UI自动化测试是一种通过模拟用户交互并自动执行UI操作的软件测试方法。它用于验证用户界面的功能和稳定性&#xff0c;以确保在不同的操作系统、浏览器和设备上的一致性。 2、UI自动化测试的优势和劣势是什么&#xff1f; 优势&#xff1…

作者头像 李华
网站建设 2026/6/23 18:10:17

Linux OOM 问题之 DMSERVER 受害者

Shell 脚本模拟(无需安装工具) OOM 问题#!/bin/bash #持续申请内存&#xff0c;每次申请 100MB&#xff0c;直到内存耗尽。while true; do # 创建 100MB 临时文件&#xff0c;读取到内存(cat 命令会占用内存)。cat /dev/zero |head -c 100M |tail & done运行脚本&#xff1…

作者头像 李华
网站建设 2026/6/23 2:05:11

Flutter引擎裁剪与鸿蒙方舟编译协同优化

欢迎大家加入开源鸿蒙跨平台开发者社区&#xff0c;一起共建开源鸿蒙跨平台生态。 Flutter引擎裁剪与鸿蒙方舟编译协同优化 Flutter引擎的冗余模块会增加包体积并影响启动速度。通过分析flutter_engine源代码&#xff0c;可识别非必要模块进行裁剪。常见可移除模块包括&#…

作者头像 李华