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

相关推荐
IT技术分享社区18 小时前
MySQL统计查询优化:内存临时表的正确打开方式
数据库·mysql·程序员
长安er19 小时前
LeetCode215/347/295 堆相关理论与题目
java·数据结构·算法·leetcode·
元亓亓亓19 小时前
LeetCode热题100--62. 不同路径--中等
算法·leetcode·职场和发展
小白菜又菜19 小时前
Leetcode 1925. Count Square Sum Triples
算法·leetcode
登山人在路上20 小时前
Nginx三种会话保持算法对比
算法·哈希算法·散列表
写代码的小球21 小时前
C++计算器(学生版)
c++·算法
AI科技星21 小时前
张祥前统一场论宇宙大统一方程的求导验证
服务器·人工智能·科技·线性代数·算法·生活
Fuly102421 小时前
大模型剪枝(Pruning)技术简介
算法·机器学习·剪枝
Xの哲學21 小时前
Linux网卡注册流程深度解析: 从硬件探测到网络栈
linux·服务器·网络·算法·边缘计算
bubiyoushang8881 天前
二维地质模型的表面重力值和重力异常计算
算法