题解 | #【模板】栈#

【模板】栈

http://www.nowcoder.com/practice/104ce248c2f04cfb986b92d0548cccbf

思路:

使用 LinkedList 结构模拟 Stack 结构。

  1. 当需要进行 push 操作时,在 队尾 插入数据
  2. 当需要进行 pop 或者 top 操作时,先判断 队列是否为空。如果队列 为空,返回 error;如果队列 不为空,返回 队尾数据
  3. 当然,可以使用 两个Queue 模拟 Stack。具体操作就是,插入 一个数据时,可以先将 队列1 中的所有元素转移到 队列2 中,然后往 队列1 中插入 新元素,最后,再将 队列2 中的元素转移回 队列1 中。但需要注意的是,此方法在 数据量大 的时候,会 超时
import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int n = Integer.valueOf(scan.nextLine().trim());
        ArrayList<String> ans = new ArrayList<>();
        for (int i = 0; i < n; i++) {
            String[] operators = scan.nextLine().split(" ");
            if ("push".equals(operators[0])) {
                push(operators[1]);
            } else if ("pop".equals(operators[0])) {
                ans.add(pop());
            } else {
                ans.add(top());
            }
        }
        for (String str : ans) {
            System.out.println(str);
        }
    }
    public static LinkedList<String> ll = new LinkedList<>();
    public static void push(String num) {
        ll.add(num);
    }
    public static String pop() {
        if (ll.isEmpty()) {
            return "error";
        } else {
            String str = ll.peekLast();
            ll.removeLast();
            return str;
        }
    }
    public static String top() {
        return ll.isEmpty() ? "error" : String.valueOf(ll.peekLast());
    }
}
全部评论
该牛油正在参与牛客写题解薅羊毛的活动,牛币,周边,京东卡超多奖品放送,活动进入倒计时!快来捡漏啦https://www.nowcoder.com/discuss/888949?source_id=profile_create_nctrack&channel=-1
点赞 回复 分享
发布于 2022-04-20 17:07

相关推荐

首先讲三个故事,关于牛客的事件一:2024年,牛客上有一对高学历情侣,求职方向与我当时一致,都是嵌入式方向。他们恰好是我的朋友,专业能力和学历背景都很扎实,也因此拿到了不少优质offer。和很多求职者一样,他们把offer情况整理后发在平台上,本意是记录与交流,但很快引发了争议。有声音指责他们“集邮”“不释放名额”,认为这种展示本身就是一种炫耀。最终讨论失控,当事人删除内容,事件也很快被遗忘。事件二:小红书评论区,一条评价获得了不少共鸣:“感觉牛客就是当年那群做题区毕业了开始找工作还收不住那股味,颇有一种从年级第一掉到年纪第二后抱怨考不上大学的味道”,这条评论被水印里这个同学转发到牛客后,评论...
小型域名服务器:当看到别人比自己强的时候,即便这是对方应得的,很多人会也下意识的歪曲解构对方的意图,来消解自己在这本就不存在的比较中输掉的自信,从而平白制造出很多无谓的争论。比如你会在空余时间来写优质好文,而我回家只会暗区突围,那么我就可以作为键盘侠在这里评论你是不是XXXXXXXX。即便我自己都知道这是假的,但只要这没那么容易证伪,那么当你开始回应的时候,脏水就已经泼出去了,后面可能会有更多的人带着情绪来给我点赞,而毫不关注你写的文章内容本身是啥了。
SAGIMA牛马咖啡
点赞 评论 收藏
分享
程序员花海:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务