LeetCode in Kotlin

2418. Sort the People

Easy

You are given an array of strings names, and an array heights that consists of distinct positive integers. Both arrays are of length n.

For each index i, names[i] and heights[i] denote the name and height of the ith person.

Return names sorted in descending order by the people’s heights.

Example 1:

Input: names = [“Mary”,”John”,”Emma”], heights = [180,165,170]

Output: [“Mary”,”Emma”,”John”]

Explanation: Mary is the tallest, followed by Emma and John.

Example 2:

Input: names = [“Alice”,”Bob”,”Bob”], heights = [155,185,150]

Output: [“Bob”,”Alice”,”Bob”]

Explanation: The first Bob is the tallest, followed by Alice and the second Bob.

Constraints:

Solution

class Solution {
    fun sortPeople(names: Array<String>, heights: IntArray): Array<String> {
        quicksort(names, heights, 0, heights.size - 1)
        return names
    }

    private fun quicksort(names: Array<String>, heights: IntArray, low: Int, high: Int) {
        if (low >= high) {
            return
        }
        var start = low
        var end = high
        val mid = start + (end - start) / 2
        val pivot = heights[mid]
        while (start < end) {
            while (heights[start] > pivot) {
                start++
            }
            while (heights[end] < pivot) {
                end--
            }
            val tempHeight = heights[start]
            heights[start] = heights[end]
            heights[end] = tempHeight
            val tempName = names[start]
            names[start] = names[end]
            names[end] = tempName
        }
        quicksort(names, heights, low, end - 1)
        quicksort(names, heights, start + 1, high)
    }
}