Notice
Recent Posts
Recent Comments
Link
«   2024/11   »
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
Tags
more
Archives
Today
Total
관리 메뉴

코드와이

[SW Expert Academy] 1258. [S/W 문제해결 응용] 7일차 - 행렬찾기 본문

SW_Expert

[SW Expert Academy] 1258. [S/W 문제해결 응용] 7일차 - 행렬찾기

코드와이 2021. 3. 16. 18:24

 

문제링크

swexpertacademy.com/main/code/problem/problemDetail.do?problemLevel=4&contestProbId=AV18LoAqItcCFAZN&categoryId=AV18LoAqItcCFAZN&categoryType=CODE&problemTitle=&orderBy=PASS_RATE&selectCodeLang=JAVA&select-1=4&pageSize=10&pageIndex=3

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com

 

package D4;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.StringTokenizer;

public class 행렬찾기 {

	static int n, r, c;
	static int[][] arr;
	static boolean[][] visited;
	
	public static void main(String[] args) throws NumberFormatException, IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st;
		StringBuilder sb = new StringBuilder();
		
		int T = Integer.parseInt(br.readLine());
		
		for(int tc = 1; tc <= T ; tc++) {
			sb.append("#").append(tc).append(" ");
			
			n = Integer.parseInt(br.readLine());
			arr = new int[n][n];
			visited = new boolean[n][n];
			
			for(int i = 0 ; i < n ; i++) {
				st = new StringTokenizer(br.readLine());
				for(int j = 0 ; j < n ; j++) {
					arr[i][j] = Integer.parseInt(st.nextToken());
				}
			}

			ArrayList<int[]> list = new ArrayList<int[]>();
			for(int i = 0 ; i < n ; i++) {
				for(int j = 0 ; j < n ; j++) {
					if(arr[i][j] != 0 && !visited[i][j]) {
						r = 1;
						c = 1;
						go(i,j,i,j);
						list.add(new int[] {r,c});
					}
				}
			}
			
			Collections.sort(list, new Comparator<int[]>() {

				@Override
				public int compare(int[] o1, int[] o2) {
					if(o1[0]*o1[1] == o2[0]*o2[1]) {
						return o1[0] - o2[0];
					}
					return o1[0]*o1[1] - o2[0]*o2[1];
				}
			});
			
			sb.append(list.size()).append(" ");
			
			for(int[] l: list) {
				sb.append(l[0]).append(" ").append(l[1]).append(" ");
			}
			sb.setLength(sb.length()-1);
			sb.append("\n");
		}
		sb.setLength(sb.length()-1);
		System.out.println(sb);
		
	}

	static int[] dr = {1,0};
	static int[] dc = {0,1};
	private static void go(int sr, int sc, int i, int j) {
		
		visited[i][j] = true;
		
		for(int d = 0 ; d < 2 ; d++) {
			int nr = i + dr[d];
			int nc = j + dc[d];
			if(nr < n && nc < n && arr[nr][nc] != 0 && !visited[nr][nc]) {
				r = Math.max(r, nr - sr + 1);
				c = Math.max(c, nc - sc + 1);
				go(sr, sc, nr, nc);
			}
		}
	}
}