<
查看: 894| 回复: 4
收起左侧

[学Java/C#] 大神请进,请教一个stack的问题

ChrisSun1996 | 显示全部楼层
本楼:   👍  0
0%
0%
0   👎
全局:   223
95%
5%
12

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x

本人转码选手。有一个比较困惑的问题:
用for loop iterate stack,为什么是从最底层(最下面的元素)iterate到最上面呢?
大家都知道stack是first in last out.
本人比较困惑。。。

评分

参与人数 1大米 +1 收起 理由
14417335 + 1 给你点个赞!

查看全部评分


上一篇:[LC周赛赛后发布会] Weekly Contest 369
下一篇:lc周赛1680如何提高到1800分或者稳定三题?
337845818 2023-10-30 13:50:53 | 显示全部楼层
本楼:   👍  1
100%
0%
0   👎
全局:   2070
88%
12%
293
你看过stack的定义吗。。 一句话解释本质就是个数组,你虽然push, pop, 但是底层不是那么操作的。

class Stack<E> extends Vector<E> {

https://github.com/AdoptOpenJDK/ ... k.java#L49C1-L49C34

评分

参与人数 1大米 +1 收起 理由
14417335 + 1 给你点个赞!

查看全部评分

回复

使用道具 举报

mc2 2023-10-30 13:14:59 | 显示全部楼层
本楼:   👍  1
100%
0%
0   👎
全局:   329
98%
2%
8
stack 的实现常用的是用list。
那么push就是push_back();
而pop就是pop_back();
这和你说的“大家都知道stack是first in last out.”是一致的。

但是在iterate的时候,对于list来说,就是从0开始。即你说的栈底往栈顶。

评分

参与人数 3大米 +3 收起 理由
Shilcare + 1 赞一个
14417335 + 1 给你点个赞!
ChrisSun1996 + 1 赞一个

查看全部评分

回复

使用道具 举报

cto 2023-10-30 13:41:12 来自APP | 显示全部楼层
本楼:   👍  0
0%
0%
0   👎
全局:   3155
88%
12%
439
你这是用list或数组当stack用吧
一般stack没有从最底开始的操作

评分

参与人数 1大米 +1 收起 理由
14417335 + 1 给你点个赞!

查看全部评分

回复

使用道具 举报

 楼主| ChrisSun1996 2023-10-30 13:45:54 来自APP | 显示全部楼层
本楼:   👍  0
0%
0%
0   👎
全局:   223
95%
5%
12
cto 发表于 2023-10-29 22:41:12
你这是用list或数组当stack用吧
一般stack没有从最底开始的操作
不是的,你试试
Stack<Integer> stack = new Stack<>();
stack.push(2);
stack.push(3);
for (int num : stack) System.out.println(num);

评分

参与人数 1大米 +1 收起 理由
14417335 + 1 给你点个赞!

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

Advertisement
>
快速回复 返回顶部 返回列表