当前位置: 首页 > news >正文

栈 数组和链表实现

stack 栈

LIFO后进先出

应用

实现递归 编辑器的撤回工作(按下ctrl z)

数组实现

// 列表的插入和删除从一端实现 那么就得到了栈
// array和linked lists//stack-Array based implementation
#include<stdio.h>
#include<stdlib.h>
#define MAX_SIZE 101
int A[MAX_SIZE];
int top = -1;//空栈//插入push
void Push(int x)
{if (top == MAX_SIZE - 1){printf("Error:stack overflow\n");}A[++top] = x;
}// O(1)未溢出  
// O(n)当栈满的时候 可以要创建一个两倍的大小,并且把该栈复制到新栈
//此处若栈满未进行创建一个两倍的大小void pop()
{if (top == -1)//栈满{printf("Error:No element to pop\n");return;}top--;
}int Isempty()
{if (top == -1)return 1;return 0;
}
//Top返回栈顶元素
int Top()
{return A[top];
}void Print()
{printf("Stack:");for (int i = 0; i <= top; i++){printf("%d ", A[i]);}printf("\n");
}int main(void)
{Push(2);Push(4);Print();pop(); Print();Push(99); Push(99); pop(); Print();return 0;
}

链表实现

#include<stdlib.h>
#include<stdio.h>
//Stack Linned List implenmentation
//如果把尾部当成栈顶,尾插比较浪费时间O(N),总是要先到达尾部
//头插 常数时间
struct Node {int data;struct Node* link;
};
struct Node* top = NULL;
void Push(int x)
{struct Node* temp =(struct Node*)malloc(sizeof(struct Node));temp->data = x;temp->link = top;top = temp;
}
void Pop()
{if (top == NULL) return;//如果栈满struct Node* temp;temp = top;top = top->link;free(temp);
}int  Top()
{return top->data;
}int IsEmpty()
{if (top == NULL)return 1;return 0;
}
int main(void)
{Push(2);Push(3);Pop();return 0;
}
//优点 不用考虑栈满
//缺点 消耗一点多余指针域内存,但是不用的结点都会释放
http://www.lryc.cn/news/365908.html

相关文章:

  • 如何备份和恢复华为手机?
  • 微波电路S参数测量实验方案
  • SpringTask Cron表达式
  • docker与docker-compose安装
  • 跨境反向海淘系统:业务流程解析与未来发展展望
  • Python语言字母:深度解析与魅力探索
  • 基于JSP技术的社区疫情防控管理信息系统
  • 区间预测 | Matlab实现QRBiTCN分位数回归双向时间卷积神经网络注意力机制时序区间预测
  • Spring MVC中,一个HTTP请求可能会被多个Handler处理
  • Vue3 时间格式化
  • SVN中trunk,branch,tag
  • React ahooks库和React Query库使用场景分析
  • 国产AI大模型哪家强?从投资者角度简单横评5款大模型!
  • uc/OS-III多任务程序
  • 6月13日在线研讨会 | 多产品多流程多团队的ALM选择方案
  • Maven使用${revision}实现多模块版本统一管理及注意事项
  • vue2 bug求助!!!(未解决,大概是浏览器缓存的问题或者是路由的问题)
  • C++的“引用”是条寄生虫
  • 人体感应提醒 大声公+微波模块
  • 正确的功能可将热晶体管风速计线性化
  • 小程序集arcgis地图显示自定义坐标的功能实现记录!(学习笔记)
  • 谷歌医疗大模型登Nature,Med-PaLM重磅揭秘!AI医生成绩比肩人类
  • java-字符串相关类的底层原理
  • C++模板编程—学习C++类库的编程基础
  • [每周一更]-(第99期):MySQL的索引为什么用B+树?
  • 详解MySQL的MVCC机制
  • docker部署skywalking
  • Mac 使用Docker安装Elasticsearch、Kibana 、ik分词器、head
  • 【Webpack4打包机制原理解析】
  • 如何提高接口响应速度