《零基础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 && stack[len(stack)-1] == popped[j] {

stack = stack[0 : 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

相关推荐
csuzhucong3 分钟前
快餐连锁大亨
算法
ssshooter18 分钟前
小猫都能懂的大模型原理 1 - 深度学习基础
人工智能·算法·llm
Jing_Rainbow1 小时前
【AI-9/Lesson30(2025-11-12)】AI + Vibe Coding:Hulk 浏览器扩展开发全解析 —— 从需求文档到实战的完整指南🌈
前端·人工智能·程序员
慕容青峰1 小时前
【LeetCode 1925. 统计平方和三元组的数目 题解】
c++·算法·leetcode
冰西瓜6001 小时前
动态规划(一)算法设计与分析 国科大
算法·动态规划
TL滕1 小时前
从0开始学算法——第十一天(字符串基础算法)
笔记·学习·算法
文心快码BaiduComate1 小时前
CCF程序员大会码力全开:AI加速营决赛圆满落幕,大奖花落谁家?
前端·后端·程序员
roman_日积跬步-终至千里2 小时前
【计算机算法与设计(10)】习题:苹果买卖问题——分治法的经典应用
算法
deepdata_cn2 小时前
模型预测控制(MPC)算法
算法
独自破碎E2 小时前
如何用最短替换让字符串变平衡?
java·开发语言·算法·leetcode