Today I Learned

최지웅·2024년 5월 19일
0

Today I Learned

목록 보기
157/258

오늘 할일
1. LeetCode
2. 대기업 중견기업 취업전략 과제_자소서
3. 핸드폰 포맷?

오늘 한일
1. LeetCode

    1. Keys and Rooms를 해결하기 위해서는 key set과 is_visited가 필요하며 방문 시 is_visited를 처리하고, key_set에 발견한 키를 넣는다. is_visited는 key set에 들어있는 항목에 대한 방문여부이다. while을 통해 is_visited가 전부 true인데, key_set혹은 is_visited의 크기가 전체 배열과 다를 경우 false를 반환시킨다.

is_visited는 key set에 크기에 따라 동적으로 사이즈가 추가되어야한다. 이를 구현하기 위해 방문한 경우 is_visited에 room_num을 추가하여 방문을 나타내겠다. 또, key_set을 iteration해야하기에 key_set은 list형태로 .distinct()를 사용해서 중복을 제거해보겠다.

아래는 코드 초안인데, 컴파일 오류가 발생하여 디버깅 예정이다.

/*
n개 방 중에 0번 방을 제외하고 1부터 n-1까지 방이 잠겨있고 모든 방을 방문해야만 한다. 하지만 키 없이는 잠긴 방을 방문할 수 없다.

방 하나를 방문하면, 고유키를 발견할 수도 있다. 각각의 키는 해당되는 숫자를 가지고 있다. 너는 모든 키를 챙겨야만 다른 방들을 열 수 있다.

배열로 받은 rooms[i]가 방을 의미하며, i번째 방을 방문하면 얻을 열쇄가 존재한다.
만약 모든 방을 방문할 수 있다면 true를, 없다면 false를 반환해라.
 */
class Solution {
    public boolean canVisitAllRooms(List<List<Integer>> rooms) {
        List<Integer> key_list=new ArrayList<>();
        List<Integer> is_visited=new ArrayList<>();

        is_visited.add(0);
        for (int i=0; i<rooms.get(0).size(); i++){
            key_list.add(rooms.get(0).get(i));
        }
        key_list=key_list.stream().distinct().toList();

        //main_logic start
        int size=key_list.size();
        for(int i=0; i<size; i++){
            int room_num=key_list.get(i);
            is_visited.add(room_num);
            for(int j=0; j<rooms.get(room_num).size(); j++){
                int prev_key_size=key_list.size();
                key_list.add(2);
                key_list.add(rooms.get(room_num).get(j));
                key_list=key_list.stream().distinct().toList();
                int added_key_size=key_list.size();
                if(prev_key_size!=added_key_size){//실제로 추가
                    size++;//전체 iteration을 한번 더(i)
                } else{//같은 룸 추가

                }
            }
        }
        //main_logic end

        if(key_list.size()!=rooms.size())
            return false;
        else
            return true;
    }
}
profile
이제 3학년..

0개의 댓글