技术好文共享:程序员的进阶课

简介: 技术好文共享:程序员的进阶课

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。


本文链接:


一、栈的定义


【百度百科】栈作为一种数据结构,是一种只能在一端进行插入和删除操作的特殊线性表。它按照先进后出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后一个数据被第一个读出来)。栈具有记忆作用,对栈的插入与删除操作中,不需要改变栈底指针。


栈是允许在同一端进行插入和删除操作的特殊线性表。允许进行插入和删除操作的一端称为栈顶(top),另一端为栈底(bottom);栈底固定,而栈顶浮动;栈中元素个数为零时称为空栈。插入一般称为进栈(PUSH),删除则称为退栈(POP)。栈也称为后进先出表。


由于堆叠数据结构只允许在一端进行操作,因而按照后进先出(LIFO, Last In First Out)的原理运作。栈也称为后进先出表。


二、栈的示意图


三、栈的实现方式


栈可以用顺序存储,也可以用链式存储,分别称为顺序栈和链栈。


四、Java中栈的实现举例


1.利用栈实现字符串逆序


@Test


public void testStringReversal(){


Stack stack=new java.util.Stack();


String //代码效果参考:http://www.lyjsj.net.cn/wx/art_24009.html

str="Hello World!";

char【】 chars = str.toCharArray();


for (char c : chars) {


stack.push(c);


}


while (!stack.isEmpty()) {


System.out.print(stack.pop());


}


}


2.用栈实现括号匹配


假设表达式中只允许两种括号:()、{};


正确表达顺序为:()或{}或({})或{({}{})}的形式;如{(}或(})或({)}的表达形式均不对。


算法的设计思想:


  1)出现左括弧则进栈;


  2)出现右括弧则首先检测栈是否为空;


    若栈空则表明此右括弧多余,表达式不匹配。


    否则和栈顶数据比较,若匹配则栈顶出栈。


    否则表明表达式不匹配;


  3)最后若栈空,则表明匹配成功;否则表明不匹配。


/*


此题还可以引申至配对字符符匹配问题,如单引号,双引号匹配问题。


/


public class ExpStackMatching {


public boolean matching(String expression) {


if (expression == null || expression == "") {


System.out.println("输入表达式为空或没有输入表达式");


//代码效果参考:http://www.lyjsj.net.cn/wx/art_24007.html

}

Stack stack = new java.util.Stack();


for (int index = 0; index < expression.length(); index++) {


switch (expression.charAt(index)) {


case '(':


stack.push(expression.charAt(index));


break;


case '{':


stack.push(expression.charAt(index));


break;


case ')':


if (!stack.empty() && stack.peek() == '(') {


stack.pop();


}


break;


case '}':


if (!stack.empty() && stack.peek() == '{') {


stack.pop();


}


}


}


if (stack.empty())


return true;


return false;


}


public static void main(String【】 args) {


String expression = "{((1+3)+2+4)+97}";


ExpStackMatching oj = new ExpStackMatching();


boolean flag = oj.matching(expression);


if (flag) {


System.out.println("匹配成功!");


} else {


System.out.println(" 匹配失败 ");


}


}


}


五、栈的字节码解析


六、我们使用过的栈


Struts2的ValueStack(值栈)


使用栈实现浏览器的前进和后退


七、栈的总结


栈是一个概念上的工具,具体能实现什么功能可以由我们去想象。栈通过提供限制性的访问方法push()和pop(),使得程序不容易出错。


对于栈的实现,我们稍微分析就知道,数据入栈和出栈的时间复杂度都为O(1),也就是说栈操作所耗的时间不依赖栈中数据项的个数,因此操作时间很短。而且需要注意的是栈不需要比较和移动操作,我们不要画蛇添足。


参考文章

相关文章
|
机器学习/深度学习 人工智能 自然语言处理
深度学习在图像识别中的应用
本文介绍了深度学习技术在图像识别领域的应用。通过分析深度学习的原理和优势,探讨了其在图像识别中的具体应用方法和技术。同时,结合实例展示了深度学习在图像识别领域取得的显著成果,并对其未来的发展趋势进行了展望。
|
1天前
|
存储 机器学习/深度学习 人工智能
打破硬件壁垒!煎饺App:强悍AI语音工具,为何是豆包AI手机平替?
直接上干货!3000 字以上长文,细节拉满,把核心功能、使用技巧和实测结论全给大家摆明白,读完你就知道这款 “安卓机通用 AI 语音工具"——煎饺App它为何能打破硬件壁垒?它接下来,咱们就深度拆解煎饺 App—— 先给大家扒清楚它的使用逻辑,附上“操作演示”和“🚀快速上手不踩坑 : 4 条核心操作干货(必看)”,跟着走零基础也能快速上手;后续再用真实实测数据,正面硬刚煎饺 App的语音助手口令效果——创建京东「牛奶自动下单神器」口令 ,从修改口令、识别准确率到场景实用性,逐一测试不掺水,最后,再和豆包 AI 手机语音助手的普通版——豆包App对比测试下,简单地谈谈煎饺App的能力边界在哪?
|
3天前
|
云安全 监控 安全
|
8天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1053 5
|
10天前
|
机器学习/深度学习 人工智能 数据可视化
1秒生图!6B参数如何“以小博大”生成超真实图像?
Z-Image是6B参数开源图像生成模型,仅需16GB显存即可生成媲美百亿级模型的超真实图像,支持中英双语文本渲染与智能编辑,登顶Hugging Face趋势榜,首日下载破50万。
708 42
|
14天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
1140 41
|
14天前
|
人工智能 前端开发 算法
大厂CIO独家分享:AI如何重塑开发者未来十年
在 AI 时代,若你还在紧盯代码量、执着于全栈工程师的招聘,或者仅凭技术贡献率来评判价值,执着于业务提效的比例而忽略产研价值,你很可能已经被所谓的“常识”困住了脚步。
874 71
大厂CIO独家分享:AI如何重塑开发者未来十年