• leetcode - 1944. Number of Visible People in a Queue


    Description

    There are n people standing in a queue, and they numbered from 0 to n - 1 in left to right order. You are given an array heights of distinct integers where heights[i] represents the height of the ith person.

    A person can see another person to their right in the queue if everybody in between is shorter than both of them. More formally, the ith person can see the jth person if i < j and min(heights[i], heights[j]) > max(heights[i+1], heights[i+2], …, heights[j-1]).

    Return an array answer of length n where answer[i] is the number of people the ith person can see to their right in the queue.

    Example 1:

    在这里插入图片描述

    Input: heights = [10,6,8,5,11,9]
    Output: [3,1,2,1,1,0]
    Explanation:
    Person 0 can see person 1, 2, and 4.
    Person 1 can see person 2.
    Person 2 can see person 3 and 4.
    Person 3 can see person 4.
    Person 4 can see person 5.
    Person 5 can see no one since nobody is to the right of them.
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    Example 2:

    Input: heights = [5,1,2,3,10]
    Output: [4,1,1,1,0]
    
    • 1
    • 2

    Constraints:

    n == heights.length
    1 <= n <= 10^5
    1 <= heights[i] <= 10^5
    All the values of heights are unique.
    
    • 1
    • 2
    • 3
    • 4

    Solution

    Go through from right to left, use a monotonic decreasing stack, if current element is smaller than the top, then it could see only 1 people, which is the top element in the stack. Otherwise, keep popping elements from the stacks, these are all the people the current element could see, until the top element is larger than the current element.

    Time complexity: o ( n ) o(n) o(n)
    Space complexity: o ( n ) o(n) o(n)

    Code

    class Solution:
        def canSeePersonsCount(self, heights: List[int]) -> List[int]:
            stack = []
            res = []
            for i in range(len(heights) - 1, -1, -1):
                see_cnt = 0
                while stack and stack[-1] < heights[i]:
                    stack.pop()
                    see_cnt += 1
                if stack:
                    see_cnt += 1
                stack.append(heights[i])
                res.append(see_cnt)
            return res[::-1]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
  • 相关阅读:
    【图解RabbitMQ-3】消息队列RabbitMQ介绍及核心流程
    一本通1075;药房管理
    Docker 下载redis
    SAT DPLL CDCL
    Neo4j入门基础:CREATE,DELETE,SET,REMOVE(看不懂我直接吃...)
    中国企业出海应尽早把握海外社交媒体运营红利-出海传播趋势的言灵视角
    安装和使用
    新手GitHub使用指南
    uni-app 的条件编译(APP-PLUS 、H5、MP-WEIXIN )
    【HttpRunner】接口自动化测试框架
  • 原文地址:https://blog.csdn.net/sinat_41679123/article/details/136204102