LeetCode in Kotlin

2865. Beautiful Towers I

Medium

You are given a 0-indexed array maxHeights of n integers.

You are tasked with building n towers in the coordinate line. The ith tower is built at coordinate i and has a height of heights[i].

A configuration of towers is beautiful if the following conditions hold:

  1. 1 <= heights[i] <= maxHeights[i]
  2. heights is a mountain array.

Array heights is a mountain if there exists an index i such that:

Return the maximum possible sum of heights of a beautiful configuration of towers.

Example 1:

Input: maxHeights = [5,3,4,1,1]

Output: 13

Explanation: One beautiful configuration with a maximum sum is heights = [5,3,3,1,1]. This configuration is beautiful since:

It can be shown that there exists no other beautiful configuration with a sum of heights greater than 13.

Example 2:

Input: maxHeights = [6,5,3,9,2,7]

Output: 22

Explanation: One beautiful configuration with a maximum sum is heights = [3,3,3,9,2,2]. This configuration is beautiful since:

It can be shown that there exists no other beautiful configuration with a sum of heights greater than 22.

Example 3:

Input: maxHeights = [3,2,5,5,2,3]

Output: 18

Explanation: One beautiful configuration with a maximum sum is heights = [2,2,5,5,2,2]. This configuration is beautiful since:

Note that, for this configuration, i = 3 can also be considered a peak. It can be shown that there exists no other beautiful configuration with a sum of heights greater than 18.

Constraints:

Solution

import kotlin.math.max
import kotlin.math.min

class Solution {
    private fun `fun`(maxHeights: List<Int>, pickId: Int): Long {
        var ans = maxHeights[pickId].toLong()
        var min = maxHeights[pickId].toLong()
        for (i in pickId - 1 downTo 0) {
            min = min(min.toDouble(), maxHeights[i].toDouble()).toLong()
            ans += min
        }
        min = maxHeights[pickId].toLong()
        for (i in pickId + 1 until maxHeights.size) {
            min = min(min.toDouble(), maxHeights[i].toDouble()).toLong()
            ans += min
        }
        return ans
    }

    fun maximumSumOfHeights(maxHeights: List<Int>): Long {
        val n = maxHeights.size
        var ans: Long = 0
        for (i in 0 until n) {
            if (i == 0 || i == n - 1 || (
                maxHeights[i] >= maxHeights[i - 1] &&
                    maxHeights[i] >= maxHeights[i + 1]
                )
            ) {
                ans = max(ans.toDouble(), `fun`(maxHeights, i).toDouble()).toLong()
            }
        }
        return ans
    }
}