算法训练营day10 栈与队列(栈实现队列,队列实现栈,栈的应用)
创始人
2025-01-09 07:03:57
0

💡 解题思路

  1. 📝 确定输入与输出
  2. 🔍 分析复杂度
  3. 🔨 复杂题目拆分严谨且完整 地拆分为更小的可以解决的子问题(栈和队列的功能,栈和队列的应用场景)–(多总结
  4. 💭 选择处理逻辑: 根据拆分后的子问题,总结并选择合适的问题处理思路栈和队列的转换逻辑
  5. 🔎 检查特殊情况:边界条件和特殊情况
  6. 🏁 返回结果

232.用栈实现队列

    class MyQueue {         private Stack inStack;         private Stack outStack;          public MyQueue() {             inStack = new Stack<>();             outStack = new Stack<>();         }          public void push(int x) {             inStack.push(x);         }          public int pop() {             moveInToOutStack();             return outStack.pop();         }          public int peek() {             moveInToOutStack();             return outStack.peek();         }          public boolean empty() {             return inStack.isEmpty() && outStack.isEmpty();         }                  private void moveInToOutStack() {             if (outStack.isEmpty()) {                 while (!inStack.isEmpty()) {                     outStack.push(inStack.pop());                 }             }         }     } 

225. 用队列实现栈

class MyStack {      private Queue mainQueue;     private Queue auxiliaryQueue;      public MyStack() {         mainQueue = new LinkedList<>();         auxiliaryQueue = new LinkedList<>();     }      public void push(int x) {         mainQueue.offer(x);     }      public int pop() {         while(mainQueue.size() > 1) {             auxiliaryQueue.offer(mainQueue.poll());         }         int num = mainQueue.poll();         Queue temp = mainQueue;         mainQueue = auxiliaryQueue;         auxiliaryQueue = temp;         return num;     }      public int top() {         while(mainQueue.size() > 1) {             auxiliaryQueue.offer(mainQueue.poll());         }         int num = mainQueue.poll();         auxiliaryQueue.offer(num);         Queue temp = mainQueue;         mainQueue = auxiliaryQueue;         auxiliaryQueue = temp;         return num;     }      public boolean empty() {         return mainQueue.isEmpty();     } } 

20. 有效的括号

class Solution {     public static boolean isValid(String s) {         HashMap map = new HashMap<>();         map.put(')','(');         map.put('}','{');         map.put(']','[');         Stack queueStack = new Stack<>();         int len = s.length();         if (len % 2 != 0) return false;         for (int i = 0; i < len; i++) {             char ch = s.charAt(i);             if (!map.containsKey(ch)) queueStack.push(ch);             else {                 if (queueStack.isEmpty() || queueStack.pop() != map.get(ch)) return false;             }         }         return queueStack.isEmpty();     } } 

1047. 删除字符串中的所有相邻重复项 (可以用栈,下面用的双指针)

class Solution {     public static String removeDuplicates(String s) {         int j = -1;         int len = s.length();         char[] chars = s.toCharArray();         for (int i = 0; i < len; i++) {             if (j >= 0 && chars[i] == chars[j]) {                 j--;             } else {                 j++;                 chars[j] = chars[i];             }         }         return String.copyValueOf(chars, 0, j+1);     } } 

相关内容

热门资讯

绝活儿辅助!广西老友玩老是输怎... 绝活儿辅助!广西老友玩老是输怎么办(辅助挂)都是真的有辅助app(讲解有挂)在进入广西老友玩老是输怎...
法门辅助!福建13水插件(辅助... 法门辅助!福建13水插件(辅助挂)一贯是有辅助技巧(有挂技术)1、许多玩家不知道福建13水插件辅助怎...
办法辅助!潮友会app下载官方... 办法辅助!潮友会app下载官方辅助器(辅助挂)真是真的是有辅助app(有挂教程)该软件可以轻松地帮助...
妙招辅助!邯郸胡乐挂辅助(辅助... 妙招辅助!邯郸胡乐挂辅助(辅助挂)好像存在有辅助插件(有挂方略)1、上手简单,内置详细流程视频教学,...
教程书辅助!乐酷辅助(辅助挂)... 教程书辅助!乐酷辅助(辅助挂)其实存在有辅助脚本(有挂细节)乐酷辅助能透视中分为三种模型:乐酷辅助模...
学习辅助!决战卡五星辅助(辅助... 学习辅助!决战卡五星辅助(辅助挂)本来真的是有辅助软件(有人有挂)学习辅助!决战卡五星辅助(辅助挂)...
绝活辅助!边锋嘉兴麻将辅助器(... 绝活辅助!边锋嘉兴麻将辅助器(辅助挂)真是真的有辅助神器(新版有挂)1、边锋嘉兴麻将辅助器公共底牌简...
举措辅助!枫叶辅助器(辅助挂)... 举措辅助!枫叶辅助器(辅助挂)本来存在有辅助技巧(竟然有挂)1、下载好枫叶辅助器正确养号方法之后点击...
讲义辅助!点我达辅助(辅助挂)... 讲义辅助!点我达辅助(辅助挂)一直存在有辅助技巧(有人有挂)1、点我达辅助辅助器安装包、点我达辅助辅...
模块辅助!威信茶馆有挂的吗(辅... 模块辅助!威信茶馆有挂的吗(辅助挂)一直真的是有辅助脚本(揭秘有挂)1、玩家可以在威信茶馆有挂的吗线...