自学内容网 自学内容网

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

 

 


原文地址:https://blog.csdn.net/qq_39728668/article/details/145137698

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!