프로그래밍/알고리즘

프로그래머스/위클리 챌린지/입실 퇴실

Doublsb 2021. 9. 23. 19:47

https://programmers.co.kr/learn/courses/30/lessons/86048

 

풀이

- 입실, 퇴실 순서 배열이 주어진다

- 입실과 퇴실의 시간은 기록되어 있지 않으며, 입실/퇴실이 동시에 이뤄지는 경우는 없다

- 각 사람 별로 반드시 만난 사람 수를 반환해야 한다

 

- 규칙 찾느라 좀 헤맸는데, 아래와 같이 풀었다.

 

C#

using System;
using System.Linq;
using System.Collections.Generic;

public class Solution {
    public int[] solution(int[] enter, int[] leave) {

        var interSect = new List<int>();
        
        var answerHash = new Dictionary<int, HashSet<int>>();
        var answer = new int[enter.Length];
        
        for(int i=0; i<leave.Length; i++)
        {
            int index_in = Array.IndexOf(enter, leave[i]);
            
            int take_count = index_in;
            int takeLast_count = leave.Length - i - 1;
            
            if(take_count <= 0 || takeLast_count <= 0) continue;

            interSect 
                = enter.Take(take_count)
                  .Intersect(leave.TakeLast(takeLast_count)).ToList();
            
            interSect.Add(leave[i]);
            
            foreach(var inter in interSect)
            {
                if(!answerHash.ContainsKey(inter-1)) 
                    answerHash.Add(inter-1, new HashSet<int>());
                
                foreach(var node in interSect)
                {
                    if(inter == node) continue;
                    answerHash[inter-1].Add(node);
                }
            }
            
            enter[index_in] = 0;
        }
        
        foreach(var e in answerHash) answer[e.Key] += e.Value.Count;

        return answer;
    }
}

 

결과

100.0 / 100.0

 

피드백

효율성을 덜 갖다버릴 수 있는 방법을 모르겠군. 음...

반응형