学习嵌入式第二十三天——数据结构——栈

可以看成做了限制的线性表,只能在一端,增加,删除操作。元素 先进后出。

栈顶,允许增加,删除的一端,栈顶

栈底 ,不允许允许增加,删除的一端,

作用: 递归,回溯, 优先级,符号匹配。

入栈(增加),出栈(删除),获得栈顶元素(gettop)。

栈的操作:

cs 复制代码
#include "LinkStack.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
LinkStack* CreateLinkStack()
{
  LinkStack* ls = malloc(sizeof(LinkStack));
  if (NULL == ls)
  {
    perror("CreateLinkStack malloc error\n");
    return NULL;
  }
  ls->top = NULL;
  ls->clen = 0;
  return ls;
}
/**
 * @brief 入栈,增加元素 底层实现 链表的头插
 *
 * @param ls 待操作的链栈
 * @param data 需要入栈的元素
 * @return int 0 成功 非0 表示失败
 */
int PushLinkStack(LinkStack* ls, DATATYPE* data)
{
  LinkStackNode* newnode = malloc(sizeof(LinkStackNode));
  if (NULL == newnode)
  {
    perror("PushLinkStack malloc error\n");
    return 1;
  }
  memcpy(&newnode->data, data, sizeof(DATATYPE));
  newnode->next = NULL;

  newnode->next = ls->top;
  ls->top = newnode;
  ls->clen++;
  return 0;
}
/**
 * @brief 出栈 ,删除元素 ,链表的头删
 *
 * @param ls 待操作的链栈
 * @return int 0 成功 非0 表示失败
 */
int PopLinkStack(LinkStack* ls)
{
  if (IsEmptyLinkStack(ls))
  {
    printf("linkstack is empty\n");
    return 1;
  }
  LinkStackNode* tmp = ls->top;
  ls->top = ls->top->next;
  free(tmp);
  ls->clen--;
  return 0;
}
/**
 * @brief 获得栈顶元素
 *
 * @param ls 待操作的链栈
 * @return DATATYPE*  NULL 失败
 */
DATATYPE* GetTopLinkStack(LinkStack* ls)
{
  if (IsEmptyLinkStack(ls))
  {
    return NULL;
  }
  return &ls->top->data;
}
int IsEmptyLinkStack(LinkStack* ls)
{
  return 0 == ls->clen;
}
int GetSizeLinkStack(LinkStack* ls)
{
  return ls->clen;
}
int DestroyLinkStack(LinkStack* ls)
{
  while (!IsEmptyLinkStack(ls))
  {
    PopLinkStack(ls);  // clen --  free;
  }
  free(ls);
  return 0;
}
相关推荐
微露清风39 分钟前
系统性学习C++-第九讲-list类
c++·学习·list
海边夕阳20061 小时前
【每天一个AI小知识】:什么是零样本学习?
人工智能·经验分享·学习
Thexhy2 小时前
在 CentOS 7 的 Linux 系统中配置 NFS
linux·运维·学习·centos
CodeLongBear3 小时前
计算机网络学习笔记 | 传输层核心知识点总结(DAY03,匠心制作)
笔记·学习·计算机网络
晓北斗NorSnow3 小时前
机器学习核心算法与学习资源解析
学习·算法·机器学习
wdfk_prog4 小时前
[Linux]学习笔记系列 -- [kernel][time]tick
linux·笔记·学习
我命由我123455 小时前
Photoshop - Photoshop 工具栏(22)单行选框工具
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
立志成为大牛的小牛5 小时前
数据结构——三十七、关键路径(王道408)
数据结构·笔记·程序人生·考研·算法
User_芊芊君子6 小时前
【成长纪实】我的鸿蒙成长之路:从“小白”到独立开发,带你走进鸿蒙的世界
学习·华为·harmonyos·鸿蒙开发
嵌入式-老费8 小时前
自己动手写深度学习框架(快速学习python和关联库)
开发语言·python·学习