《零基础Go语言算法实战》【题目 4-3】请用 Go 语言编写一个验证栈序列是否为空的算法

《零基础Go语言算法实战》

【题目 4-3】请用 Go 语言编写一个验证栈序列是否为空的算法

给定两个具有不同值的 push 和 pop 数组序列,当且仅当这可能是对最初为空的栈的一系

列 push 和 pop 操作的结果时才返回 true。

【解答】

① 思路。

这是考查栈操作的题目,按照 push 数组的顺序先把元素压入栈,然后再依次在 pop 里面

找出栈顶元素,找到了就出栈 pop,直到遍历完 pop 数组,最终如果遍历完了 pop 数组,则

代表清空了整个栈。

② Go 语言实现。

package main

import "fmt"

func validateStack(pushed \[\]int, popped \[\]int) bool {

stack, j, N := \[\]int{}, 0, len(pushed)

for _, x := range pushed {

stack = append(stack, x)

for len(stack) != 0 && j < N && stacklen(stack)-1 == poppedj {

stack = stack0 : len(stack)-1

j++

}

}

return j == N

}

func main() {

arr1 := \[\]int{1, 6, 8}

arr2 := \[\]int{1, 6, 8}

ret := validateStack(arr1, arr2)

fmt.Println(ret)

}

//$ go run interview4-3.go

//true

相关推荐
地平线开发者2 小时前
J6B vio scenario sample
算法
BothSavage14 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn14 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
纯爱掌门人15 小时前
干了这么多年前端,聊聊 2026 年我们到底还值不值钱
前端·程序员
AskHarries16 小时前
用 OpenClaw 做一份完整 PPT:从主题、提纲到 slide deck
后端·程序员
齐翊16 小时前
分享一个在 Claude Code 里 [同时] 用多个 ApiKey 的方法
程序员·github·agent
烬羽16 小时前
从"抽卡"到"搭台":一文讲透上下文工程(Context Engineering)的底层逻辑
程序员
烬羽16 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
SimonKing16 小时前
Google第三方授权登录
java·后端·程序员