1762. Buildings With an Ocean View

There are n buildings in a line. You are given an integer array heights of size n that represents the heights of the buildings in the line.

The ocean is to the right of the buildings. A building has an ocean view if the building can see the ocean without obstructions. Formally, a building has an ocean view if all the buildings to its right have a smaller height.

Return a list of indices (0-indexed) of buildings that have an ocean view, sorted in increasing order.

Example 1:

复制代码
Input: heights = [4,2,3,1]
Output: [0,2,3]
Explanation: Building 1 (0-indexed) does not have an ocean view because building 2 is taller.

Example 2:

复制代码
Input: heights = [4,3,2,1]
Output: [0,1,2,3]
Explanation: All the buildings have an ocean view.

Example 3:

复制代码
Input: heights = [1,3,2,4]
Output: [3]
Explanation: Only building 3 has an ocean view.

Constraints:

  • 1 <= heights.length <= 105
  • 1 <= heights[i] <= 109
java 复制代码
public class Solution {
    public int[] findBuildings(int[] heights) {
        ArrayList<Integer> results = new ArrayList<Integer>();

        if (heights == null || heights.length == 0) {
            return new int[0]; // Return an empty array if input is null or empty
        }

        int highest_building = -1;

        for (int i = heights.length - 1; i >= 0; i--) {
            if (heights[i] > highest_building) {
                highest_building = heights[i];
                results.add(i); // 从右往左遍历,把最高的楼房存下来
            }
        }

        // Convert the ArrayList<Integer> to int[] 这里要特别注意,Interger的arraylist到int的array要手动转换一下。
        int[] resultArray = new int[results.size()];
        int j = 0;
        for (int i = results.size() - 1; i >=0; i--) {
            resultArray[j] = results.get(i);
            j++;
        }

        return resultArray;
    }
}
相关推荐
雾岛—听风21 分钟前
P1012 [NOIP 1998 提高组] 拼数
算法
papership1 小时前
【入门级-算法-5、数值处理算法:高精度的乘法】
数据结构·算法
earthzhang20211 小时前
【1039】判断数正负
开发语言·数据结构·c++·算法·青少年编程
谈笑也风生1 小时前
只出现一次的数字 II(一)
数据结构·算法·leetcode
蕓晨1 小时前
auto 自动类型推导以及注意事项
开发语言·c++·算法
mjhcsp1 小时前
C++ 递推与递归:两种算法思想的深度解析与实战
开发语言·c++·算法
_OP_CHEN1 小时前
算法基础篇:(三)基础算法之枚举:暴力美学的艺术,从穷举到高效优化
c++·算法·枚举·算法竞赛·acm竞赛·二进制枚举·普通枚举
m0_748248022 小时前
《详解 C++ Date 类的设计与实现:从运算符重载到功能测试》
java·开发语言·c++·算法
天选之女wow2 小时前
【代码随想录算法训练营——Day61】图论——97.小明逛公园、127.骑士的攻击
算法·图论
im_AMBER2 小时前
Leetcode 47
数据结构·c++·笔记·学习·算法·leetcode