慣性聚合 関心のあるブログ、ニュース、テクノロジーを効率的に追跡
原文を読む 慣性聚合で開く

おすすめ購読元

小众软件
小众软件
博客园 - 叶小钗
有赞技术团队
有赞技术团队
大猫的无限游戏
大猫的无限游戏
博客园_首页
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
L
LangChain Blog
Hugging Face - Blog
Hugging Face - Blog
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
aimingoo的专栏
aimingoo的专栏
Blog — PlanetScale
Blog — PlanetScale
爱范儿
爱范儿
T
Tailwind CSS Blog
Jina AI
Jina AI
量子位
Stack Overflow Blog
Stack Overflow Blog
人人都是产品经理
人人都是产品经理
J
Java Code Geeks
V
Visual Studio Blog
月光博客
月光博客

DEV Community

Authentication Security Deep Dive: From Brute Force to Salted Hashing (With Java Examples) Why AI Systems Don’t Fail — They Drift Spilling beans for how i learn for exam😁"Reinforcement Learning Cheat Sheet" I Replaced Chrome with Safari for AI Browser Automation. Here's What Broke (and What Finally Worked) How Python Borrows Other People's Work The $40 Architecture: Processing 1 Billion API Requests with 99.99% Uptime Vibe Coding: A Workflow Guide (From Zero to SaaS) Most webhook security guides protect the wrong side. The scary part is delivery. Headless CMS for TanStack Start: Build a Blog with Cosmic EU Age Verification App "Hacked in 2 Minutes" — What Actually Happened Comfy Cloud’s delete function does not actually remove files Running AI Models on GPU Cloud Servers: A Beginner Guide Event-driven media intelligence with AWS Step Functions and Bedrock I scored 500 AI prompts across 8 quality dimensions — here's what broke How to Call Google Gemini API from Next.js (Free Tier, No Backend Needed) The Portal Protocol: Reclaiming Human Connection in the Age of AI How to Fix Your Team's Scattered Knowledge Problem With a Self-Hosted Forum Intro to tc Cloud Functors: A Graph-First Mental Model for the Modern Cloud Designing Multi-Tenant Backends With Both Ownership and Team Access I Built a Neumorphic CSS Library with 77+ Components — Here's What I Learned PostgreSQL Performance Optimization: Why Connection Pooling Is Critical at Scale Cómo construí un SaaS multi-rubro para gestionar expensas en Argentina con FastAPI + Vue 3 🚀 I Built an Ethical Hacking Scanner Tool – Open Source Project I Replaced /usage and /context in Claude Code With a Single Statusline A Pythonic Way to Handle Emails (IMAP/SMTP) with Auto-Discovery and AI-Ready Design I Collected 8.9 Million Polymarket Price Points — Here's What I Found About How Markets Really Move EcoTrack AI — Carbon Footprint Tracker & Dashboard Everyone's Using AI. No One Agrees How. 5 self-hosted ebook managers worth trying in 2026 Building Your First AI Agent with LangChain: From Chatbot to Autonomous Assistant Common SOC 2 Failures (Real World) Stop Vibe-Checking Your AI App: A Practical Guide to Evals How to Use SonarQube and SonarScanner Locally to Level Up Your Code Quality Your Next To-Do App Is Dead — I Replaced Mine with an OpenClaw AI Sign a Nostr event in 60 lines of Python using coincurve — no nostr-sdk, no nbxplorer, no rust toolchain ITGC Audit Explained Like You’re in Big 4 Patch Tuesday abril 2026: Microsoft parcha 163 vulnerabilidades y un zero-day en SharePoint Stop scraping everything: a better way to track competitor price changes Listing on MCPize + the Official MCP Registry while routing payments OUTSIDE the marketplace — how I kept 100% of my x402 revenue Building an AI-Powered Risk Intelligence System Using Serverless Architecture Why We Ripped Function Overloading Out of Our AI Toolchain Testing AI-Generated Code: How to Actually Know If It Works SaaS Churn Is Killing Your Business. Here Is What to Do About It (Without a Support Team) The Speed of AI Is No Longer Linear - And Self-Improving Models Are Why How to Implement RBAC for MCP Tools: A Practical Guide for Engineering Teams From Standard Quote to Persuasive Proposal: AI Automation for Arborists I built a CLI that scaffolds complete multi-tenant SaaS apps Axios CVE-2025–62718: The Silent SSRF Bug That Could Be Hiding in Your Node.js App Right Now The dashboard that ended our friendship Data Pipelines Explained Simply (and How to Build Them with Python)
インタビューで技術的なスタック:3つの問題をステップバイステップで解決する
Axel Espinos · 2026-05-28 · via DEV Community

LeetCodeの問題を解き始めた当初、それぞれが新しい世界のように感じました。しばらくして、多くの問題が構造によってグループ化されていることに気づきました。パターンを認識すれば、問題は自ずと解けるのです。今日はスタックの問題です.

前回の記事ではスタックの動作について見ました。今日はその基礎を活かして、三つの古典的な問題を解決します。

Tres problemas distintos (balanced parentheses, reverse string, simplify path) convergiendo en un mismo stack que los resuelve

ここで見つけるもの:

  • ステップバイステップで解決する三つの問題: 平衡した括弧、文字列の逆転、パスの簡略化
  • スタックがインタビューの外でどのように現れるか

急いで思い出そう

LIFO: 最後に追加されたものが最初に取り出される。push頂部に追加するpop トップから取り出す。JavaScriptでは配列はすでにスタックとして機能している。完全な詳細が必要な場合は、前の記事にある。

さて、問題に進む。

問題1: 平衡した括弧

LeetCodeの「Valid Parentheses」

問題: 文字列sが与えられ、それにはただ()[]{} が有効かどうか確認します。各開始タグには対応する閉じタグがあり、正しい順序で配置されている必要があります。


Input:  "()[]{}"   → true
Input:  "([)]"     → false
Input:  "{[]}"     → true

フルスクリーンモードを開始 フルスクリーンモードを終了

どう考えますか?

「最後に開いたものが最初に閉じられる」これがスタックが正しく行うことです。

文字列をたどります。各開き括弧はスタックに格納されます。各閉じ括弧はスタックの一番上と一致する必要があります。最後にスタックが空なら、すべて閉じたことを意味します.

Paso a paso del stack validando balanced parentheses

解決策

function validParentheses(s) {
  const stack = [];
  const pairs = { ")": "(", "}": "{", "]": "[" };

  for (const char of s) {
    if (char === "(" || char === "{" || char === "[") {
      stack.push(char);
    } else if (stack.pop() !== pairs[char]) {
      return false;
    }
  }

  return stack.length === 0;
}

フルスクリーンモードを開始 フルスクリーンモードを終了

重要な点:

  1. pairs閉じ括弧をそれぞれの開き括弧に対応させます.
  2. 開き括弧はスタックに格納されます。閉じ括弧はpopし、検証します。
  3. スタックが空である場合にpopを実行すると、undefinedを返し、比較が失敗します。楽です、これで追加のチェックは必要ありません.
  4. 最終的に、スタックは空である必要があります.

複雑性:O(n)時間とO(n)空間.

問題2:文字列の反転(簡単)

LeetCodeの"Reverse String"のアダプテーションスタックを使って単語を逆転させます

問題: 文字列sを与えられたら、その逆順の文字列を返します


Input:  "stack"   → "kcats"
Input:  "hello"   → "olleh"

フルスクリーンモードに入る フルスクリーンモードから退出する

どう考えたか?

「逆転させる」がヒントです。順番に要素を入れて、逆順に取り出す。それがスタックがするのと同じです。

実際にはs.split("").reverse().join("")を使えばいいし、それだけ。ここではスタックを使ってパターンが実際にどう動作するかを見る。

Paso a paso del stack invirtiendo la palabra stack

解決策

var reverseString = function (s) {
  const stack = [...s]; // crea un stack con los caracteres
  let reversed = "";

  while (stack.length > 0) {
    reversed += stack.pop();
  }

  return reversed;
};

フルスクリーンモードに入る フルスクリーンモードから抜ける

全ての文字をスタックに入れ、一つずつ取り出す。popが最後に入ったものを返すので、文字は逆順で出てくる。

複雑性:O(n)時間とO(n)空間.

問題3:パスを簡略化する(中級)

LeetCodeの「Simplify Path」.

問題:Unixの絶対パスをその標準形に変換する.

ルール:

  • .は現在のディレクトリを意味する.
  • ..は一つ上の階層に移動する.
  • ///と扱われる.
  • の結果は/で終わらない、根を除く.

Input:  "/home//foo/"       → "/home/foo"
Input:  "/../"              → "/"
Input:  "/a/./b/../../c/"   → "/c"

フルスクリーンモードを開始 フルスクリーンモードを終了

どう考えたか?

..は何をする? 直前のディレクトリに戻る.

そこに信号がある、私たちは通った道を覚えて戻れる必要がある.__JHSNS_SEG_9c3f6c85_74__ルートを分割する/ それぞれのコンポーネントをたどります:

  • "" または "." は無視します。
  • ".." でスタックのトップを取り出します。
  • その他はディレクトリでスタックに追加されます。

最終的に、スタックには簡略化されたパスのディレクトリが含まれます。

Paso a paso del stack simplificando una ruta de Unix

解決策

var simplifyPath = function (path) {
  const stack = [];

  for (const part of path.split("/")) {
    if (part === "" || part === ".") continue;
    if (part === "..") stack.pop();
    else stack.push(part);
  }

  return "/" + stack.join("/");
};

フルスクリーンモードに入る フルスクリーンモードから退出する

ヒント: JavaScriptにおいて、popがスタックが空である場合に何も壊さず、undefinedを返すだけです。そのため、ルートが根元を超えてアップロードしようとする場合、追加の検証は不要です。

複雑性: O(n)時間とO(n)空間です。

三つのパターン背後にあるもの

順番に読んでみると同じことに気づくでしょう。三者は根本的な同じ問題を解決します。以前の状態に戻る能力です.

  • バランスの取れた括弧:閉じ括弧を検証するために最後の開き括弧を覚える.
  • 文字列の反転:逆の順序に戻る.
  • パスの簡略化:.. は一つ階層を戻します.

それはスタックのスーパーポワーだ。問題が最後に覚えておくこと、何かを取り消すこと、後ろから処理することを求める時、ほとんどの場合、答えはスタックだ.

インタビューを超えたスタック

スタックはインタビューの trivia ではない。『戻る』というパターンは至る所に現れる:

  • ブラウザの戻るボタンはスタックだ.
  • あなたのエディタの undo/redo もそうだ.
  • 言語のスタックトレース(そのためスタックオーバーフローエラーが存在する).
  • データパイプラインは最後に見たもののコンテキストを保持する必要がある.

実践を続けるために

LeetCodeの難易度順に並べられた問題:

  1. Min Stack、簡単.
  2. Baseball Game、簡単.
  3. 逆ポーランド記法の評価、中級
  4. 日々の気温、中級。これは単調スタックのパターンの導入です

。どれが最も難しかった?コメントで教えてください。私にとってはSimplify Pathが解決するのに少し時間がかかりました。