765. Couples Holding Hands
Description
There are n
couples sitting in 2n
seats arranged in a row and want to hold hands.
The people and seats are represented by an integer array row
where row[i]
is the ID of the person sitting in the ith
seat. The couples are numbered in order, the first couple being (0, 1)
, the second couple being (2, 3)
, and so on with the last couple being (2n - 2, 2n - 1)
.
Return the minimum number of swaps so that every couple is sitting side by side. A swap consists of choosing any two people, then they stand up and switch seats.
Example 1:
Input: row = [0,2,1,3] Output: 1 Explanation: We only need to swap the second (row[1]) and third (row[2]) person.
Example 2:
Input: row = [3,2,0,1] Output: 0 Explanation: All couples are already seated side by side.
Constraints:
2n == row.length
2 <= n <= 30
n
is even.0 <= row[i] < 2n
- All the elements of
row
are unique.
Solutions
Solution: Greedy
- Time complexity: O(n)
- Space complexity: O(n)
JavaScript
js
/**
* @param {number[]} row
* @return {number}
*/
const minSwapsCouples = function (row) {
const n = row.length;
const peoples = [];
let result = 0;
for (let index = 0; index < n; index++) {
const people = row[index];
peoples[people] = index;
}
for (let index = 1; index < n; index += 2) {
const current = row[index];
const couple = row[index - 1];
const target = couple % 2 ? couple - 1 : couple + 1;
if (current === target) continue;
const swapIndex = peoples[target];
peoples[target] = index;
peoples[current] = swapIndex;
[row[index], row[swapIndex]] = [row[swapIndex], row[index]];
result += 1;
}
return result;
};