-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy path0946-validate-stack-sequences.rb
59 lines (49 loc) · 1.48 KB
/
0946-validate-stack-sequences.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# frozen_string_literal: true
# 946. Validate Stack Sequences
# https://leetcode.com/problems/validate-stack-sequences/
# Medium
=begin
Given two integer arrays pushed and popped each with distinct values, return true if this could have been the result of a sequence of push and pop operations on an initially empty stack, or false otherwise.
### Example 1:
Input: pushed = [1,2,3,4,5], popped = [4,5,3,2,1]
Output: true
Explanation: We might do the following sequence:
push(1), push(2), push(3), push(4),
pop() -> 4,
push(5),
pop() -> 5, pop() -> 3, pop() -> 2, pop() -> 1
### Example 2:
Input: pushed = [1,2,3,4,5], popped = [4,3,5,1,2]
Output: false
Explanation: 1 cannot be popped before 2.
### Constraints:
* 1 <= pushed.length <= 1000
* 0 <= pushed[i] <= 1000
* All the elements of pushed are unique.
* popped.length == pushed.length
* popped is a permutation of pushed.
=end
# @param {Integer[]} pushed
# @param {Integer[]} popped
# @return {Boolean}
def validate_stack_sequences(pushed, popped)
stack = []
for x in pushed
stack << x
while stack.last && stack.last == popped.first
stack.pop
popped.shift
end
end
popped.empty?
end
# ********************#
# TEST #
# ********************#
require "test/unit"
class Test_validate_stack_sequences < Test::Unit::TestCase
def test_
assert_equal true, validate_stack_sequences([1, 2, 3, 4, 5], [4, 5, 3, 2, 1])
assert_equal false, validate_stack_sequences([1, 2, 3, 4, 5], [4, 3, 5, 1, 2])
end
end