[알고리즘] LeetCode - Cinema Seat Allocation

Jerry·2021년 8월 20일
0

LeetCode

목록 보기
66/73
post-thumbnail

LeetCode - Cinema Seat Allocation

문제 설명

A cinema has n rows of seats, numbered from 1 to n and there are ten seats in each row, labelled from 1 to 10 as shown in the figure above.

Given the array reservedSeats containing the numbers of seats already reserved, for example, reservedSeats[i] = [3,8] means the seat located in row 3 and labelled with 8 is already reserved.

Return the maximum number of four-person groups you can assign on the cinema seats. A four-person group occupies four adjacent seats in one single row. Seats across an aisle (such as [3,3] and [3,4]) are not considered to be adjacent, but there is an exceptional case on which an aisle split a four-person group, in that case, the aisle split a four-person group in the middle, which means to have two people on each side.

입출력 예시

Example 1:

Input: n = 3, reservedSeats = [[1,2],[1,3],[1,8],[2,6],[3,1],[3,10]]
Output: 4
Explanation: The figure above shows the optimal allocation for four groups, where seats mark with blue are already reserved and contiguous seats mark with orange are for one group.

Example 2:

Input: n = 2, reservedSeats = [[2,1],[1,8],[2,6]]
Output: 2

제약사항

1 <= n <= 10^9
1 <= reservedSeats.length <= min(10*n, 10^4)
reservedSeats[i].length == 2
1 <= reservedSeats[i][0] <= n
1 <= reservedSeats[i][1] <= 10
All reservedSeats[i] are distinct.

Solution

[전략]
1. 배열을 row, column 순으로 정렬하여
2. 각각의 reservedSeat 사이가 4명이 앉을수있는 곳인지 판단한다

import java.util.*;

class Solution {
    public int maxNumberOfFamilies(int n, int[][] reservedSeats) {

        Arrays.sort(reservedSeats, (a, b) -> a[0] == b[0] ? a[1] - b[1] : a[0] - b[0]);
        int rowNum = 1;
        int lastOccupied = 0;
        int count = 0;
        for (int i = 0; i < reservedSeats.length; i++) {

            if (reservedSeats[i][0] > rowNum) { // row 바뀜

                int diffRow = reservedSeats[i][0] - rowNum;
                // 한줄이 전체 비었을때 최대 2 그룹이 앉을 수 있음
                if (diffRow > 1) {
                    count += (diffRow - 1) * 2;
                }
                // 이전 줄의 마지막 자리가 어디냐에 따라 달라짐
                if (lastOccupied < 2) {
                    count += 2;
                } else if (lastOccupied < 6) {
                    count++;
                }
                rowNum = reservedSeats[i][0];
                lastOccupied = 0;
            }

            if (reservedSeats[i][1] >= 6 && reservedSeats[i][1] <= 7) {
                if (lastOccupied < 2) {
                    count++;
                }
            } else if (reservedSeats[i][1] >= 8 && reservedSeats[i][1] <= 9) {
                if (lastOccupied < 4) {
                    count++;
                }
            } else if (reservedSeats[i][1] == 10) {
                if (lastOccupied < 2) {
                    count += 2;
                } else if (lastOccupied < 6) {
                    count++;
                }
            }

            lastOccupied = reservedSeats[i][1];
        }

        if (lastOccupied < 2) {
            count += 2;
        } else if (lastOccupied < 6) {
            count++;
        }
        if (rowNum < n) {
            count += (n - rowNum) * 2;
        }
        return count;
    }
}
profile
제리하이웨이

8개의 댓글

comment-user-thumbnail
2025년 3월 17일

To be a Rookie, My business is for good researching on the net intended for articles or blog posts which might be connected with assistance to everyone. Appreciate it. field service software reviews

답글 달기
comment-user-thumbnail
2025년 3월 20일

Excellent writing. This write-up has effects on many critical troubles your contemporary society. Most of us cannot be uninvolved to help most of these troubles. That write-up allows good ideas in addition to methods. Incredibly beneficial in addition to realistic. cash for cars Brisbane

답글 달기
comment-user-thumbnail
2025년 3월 21일

I just concept it will be an example to write incase everyone else was basically experiencing difficulity considering and yet I'm sure a little bit of suspicious considerably more than simply morning allowed to position manufacturers not to mention talks about concerning in this case. Door handles

답글 달기
comment-user-thumbnail
2025년 3월 26일

A beats might be fantastic. You possess numerous especially capable actors. I just aspire most people the right from victory. https://www.clusterrepairsuk.co.uk/

답글 달기
comment-user-thumbnail
7일 전

I might point out in which it is a a fantastic submit of your fantastic particular person, now i'm pleased to notice this kind of.大和高田 ヘルニア

답글 달기
comment-user-thumbnail
3일 전

You might be allowed to submit brands, however, not back links, except if they may be accepted and also about matter. https://en.wikipedia.org/wiki/Field_force_automation

답글 달기
comment-user-thumbnail
2일 전

This specific is a great article My spouse and i witnessed due to talk about the idea. It is definitely precisely what I want to to view expect throughout potential you can proceed pertaining to expressing a real exceptional article. parawany

답글 달기
comment-user-thumbnail
2일 전

This really is therefore stunning as well as innovative. I simply adore the actual colours as well as whomever will get this within the postal mail is going to be grinning. winmax

답글 달기

관련 채용 정보