《零基础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

相关推荐
向上的车轮8 分钟前
“傅里叶变换算法”来检测纸箱变形的简单示例
算法
九亿AI算法优化工作室&22 分钟前
乡村地区无人机医药配送路径规划与优化仿真
人工智能·算法·matlab·回归
米粉030537 分钟前
算法图表总结:查找、排序与递归(含 Mermaid 图示)
数据结构·算法·排序算法
人类发明了工具1 小时前
【优化算法】协方差矩阵自适应进化策略(Covariance Matrix Adaptation Evolution Strategy,CMA-ES)
线性代数·算法·矩阵·cma-es
黑色的山岗在沉睡1 小时前
LeetCode100.4 移动零
数据结构·算法·leetcode
方博士AI机器人1 小时前
算法与数据结构 - 二叉树结构入门
数据结构·算法·二叉树
-qOVOp-1 小时前
zst-2001 上午题-历年真题 算法(5个内容)
算法
全栈凯哥2 小时前
Java详解LeetCode 热题 100(17):LeetCode 41. 缺失的第一个正数(First Missing Positive)详解
java·算法·leetcode
ai.Neo2 小时前
牛客网NC22157:牛牛学数列2
数据结构·c++·算法
Nobkins3 小时前
2023CCPC河南省赛暨河南邀请赛个人补题ABEFGHK
开发语言·数据结构·c++·算法·图论