티스토리 뷰

문제

 

프로그래머스

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

programmers.co.kr


풀이

  • 배열의 들어가는 수가 여러개라 당황했었지만 BFS로 생각보다 간단하게 풀 수 있는 문제였다
  • 색깔이 같은 부분만 count를 해줘야하므로 현재 탐색중인 노드와 다음에 탐색할 노드의 값이 같은지 비교한 후 큐에 넣어줘야한다

코드

class Soultion {
	
	static public int[] solution(int m, int n, int[][] picture) {
	      int numberOfArea = 0;
	      int maxSizeOfOneArea = 0;
	      int[] answer = new int[2];     
	      int[][] visit = new int[m][n];
	     
	      for(int i=0; i<m; i++) {
	    	  for(int j=0; j<n; j++) {
	    		  if(visit[i][j]==1 | picture[i][j]==0) continue;
	    		  // 가장 큰 영역의 count 값만 저장
	    		  maxSizeOfOneArea = Math.max(bfs(picture, visit, i,j,m, n), maxSizeOfOneArea);
	    		  // 함수를 한번 실행하면 하나의 영역을 찾은 것이므로 +1
	    		  numberOfArea++;
	    	  }
	      }
	      
	      answer[0] = numberOfArea;
	      answer[1] = maxSizeOfOneArea;
	      return answer;
	  }
	
	static int bfs(int[][] picture, int[][] visit, int x, int y, int m, int n) {
		Queue<int[]> queue = new LinkedList<int[]>();
		int[] dx = {0,0,-1,1};
		int[] dy = {-1,1,0,0};
		int count=1; // 매개변수로 들어온 좌표의 위치도 포함해야하므로 1로 초기화
		
		visit[x][y] = 1;
		queue.offer(new int[] {x,y});
		
		while (!queue.isEmpty()) {
			int[] now = queue.poll();
			
			for(int i=0; i<4; i++) {
				int nx = now[0] + dx[i];
				int ny = now[1] + dy[i];
				
				// 다음 탐색할 노드가 유효한 범위 이내에 있지 않거나 값이 0이라면 다음 노드 탐색
				if(nx<0 || nx>=m || ny<0 || ny>=n || visit[nx][ny]==1 || picture[nx][ny]==0) continue;
				// 색이 같은 노드만 탐색해야하므로 값을 비교
				if(picture[nx][ny] == picture[now[0]][now[1]]) {
					visit[nx][ny] =1;
					queue.offer(new int[] {nx,ny});
					count++;
				}
			}		
		}
		return count;
	}
}

 

공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
TAG
more
«   2024/10   »
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31
글 보관함