알고리즘 문제 해결(PS)/[백준]
[백준] 1022번 소용돌이 예쁘게 출력하기 (자바 풀이)
연구소장 J
2022. 3. 22. 10:54
문제
https://www.acmicpc.net/problem/1022
풀이
모든 숫자를 계산해서 저장하는 것은 메모리의 한계로 가능하지 않다(10000*10000=1억 개의 int)
따라서 숫자는 계속해서 계산해나가면서, 범위에 있는 배열에만 값을 저장하면 된다.
이때 map[r2-r1+1][c2-c1+1] 을 선언해서 사용하면 된다.
자세한 내용은 코드를 참고하자.
코드
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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 | import java.io.*; import java.util.Scanner; public class Baekjoon_1022 { static int r1,c1,r2,c2,max=0; static int map[][]; static int[] dx = {0,-1,0,1}; static int[] dy = {1,0,-1,0}; public static void main(String[] args) { Scanner sc = new Scanner(System.in); r1 = sc.nextInt(); c1 = sc.nextInt(); r2 = sc.nextInt(); c2 = sc.nextInt(); map = new int[r2-r1+1][c2-c1+1]; fill(); print(); } public static void fill() { int x=0, y=0, dir=0; int num=1, len =1, cnt =0; while(!endCheck()) { if(x >= r1 && x<=r2 && y>= c1 && y <= c2) { // 범위내에 오면 map[x-r1][y-c1] = num; } num++; cnt++; x = x + dx[dir]; y = y + dy[dir]; if(cnt == len) { cnt = 0; if(dir == 1 || dir == 3) { // 방향이 위나 아래였으면 길이가 1 증가됨 len++; } dir = (dir+1)%4; // 방향 전환 } } max = num - 1; // 최댓값 저장 } /* 원하는 좌표에 값이 모두 채워졌는지 확인 */ public static boolean endCheck() { return map[0][0] != 0 && map[r2-r1][0] != 0 && map[0][c2-c1]!=0 && map[r2-r1][c2-c1]!=0; } public static void print() { int maxLen = (int)Math.log10(max); // 자릿수 계산 int len; for(int i=0; i<=r2-r1; i++) { for(int j=0; j<= c2-c1; j++) { len = maxLen - (int) Math.log10(map[i][j]); // 최댓값 자릿수와 차이 계산 for(int k=0; k<len; k++) { // 차이만큼 공백 붙여주기 System.out.print(" "); } System.out.print(map[i][j]+ " "); } System.out.println(); } } } | cs |
반응형