본문 바로가기
Algorithm/Programmers Java

Java 프로그래머스 석유 시추

by 제우제우 2024. 3. 1.

https://school.programmers.co.kr/learn/courses/30/lessons/250136

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

문제 분류 : 코딩테스트 연습 > PCCP 기출문제 > [PCCP 기출문제] 2번 / 석유 시추

난이도 : 2

 

시간 초과 코드

import java.util.*;
class Solution {
    static int [] arx = {-1,1,0,0};
    static int [] ary = {0,0,-1,1};
    public int solution(int[][] land) {
        // 0이면 빈땅 1이면 석유 
        int answer = 0;
        boolean [][] visited;
        int a = land.length; 
        int b = land[0].length;
        for(int i = 0; i < b; i++){
            int sum = 0;
            visited = new boolean[a][b];
            Queue<int[]> q = new LinkedList<>();
            for(int j = 0; j < a; j++){
                if(land[j][i] == 0) continue;
                visited[j][i] = true;
                sum++;
                q.add(new int[]{j, i});
            }
            while(!q.isEmpty()){
                int [] cur = q.poll();
                for(int k = 0; k < 4; k++){
                    int nx = arx[k] + cur[0];
                    int ny = ary[k] + cur[1];
                    if(0 <= nx && 0 <= ny && nx < a && ny < b){
                        if(land[nx][ny] == 1 && !visited[nx][ny]){
                            visited[nx][ny] = true;
                            sum++;
                            q.add(new int[]{nx,ny});
                        }
                    }
                }
            }
            answer = Math.max(answer, sum);
        }
        
        return answer;
    }
}

정확성 테스트는 전부 통과 하지만 효율성 테스트를 전부 틀렸다. -> 60점 

 

정답 코드

import java.util.*;
class Solution {
    static int [] arx = {-1,1,0,0};
    static int [] ary = {0,0,-1,1};
    public int solution(int[][] land) {
        // 0이면 빈땅 1이면 석유 2, 3, 4, 5, 6, ... 발견한 석유 
        int answer = 0;
        boolean [][] visited;
        int a = land.length; 
        int b = land[0].length;
        HashMap<Integer, Integer> map = new HashMap<>(); // 석유갱 이름, 크기
        int cnt = 2; // 석유 이름 
        for(int i = 0; i < a; i++){
            for(int j = 0; j < b; j++){
                if(land[i][j] == 1){
                    int sum = 1;
                    land[i][j] = cnt;
                    Queue<int [] > q = new LinkedList<>();
                    q.add(new int[]{i, j});
                    while(!q.isEmpty()){
                        int [] cur = q.poll();
                        for(int k = 0; k < 4; k++){
                            int nx = arx[k] + cur[0];
                            int ny = ary[k] + cur[1];
                            if(0 <= nx && 0 <= ny && nx < a && ny < b){
                                if(land[nx][ny] == 1){
                                    land[nx][ny] = cnt;
                                    sum++;
                                    q.add(new int[]{nx,ny});
                                }
                            }
                        }
                    }
                    map.put(cnt, sum); // 석유갱 이름, 석유 크기 
                    cnt++;
                }
            }
        }
        for(int i = 0; i < b; i++){
            Set<Integer> set = new HashSet<>();
            for(int j = 0; j < a; j++){
                if(land[j][i] == 0) continue;
                set.add(land[j][i]);
            }
            Iterator<Integer> it = set.iterator();
            int sum = 0;
            while(it.hasNext()){
                int next = it.next();
                sum += map.get(next);
            }
            answer = Math.max(answer, sum);
        }
        
        return answer;
    }
}

1. BFS를 사용해서  석유갱을 찾고 이름을 붙인다. 이름과 크기를 Map에 저장

2. 열마다 붙어있는 석유갱을 찾고 석유갱의 크기를 더한다. Max 값과 비교해서 갱신