[JAVA] SWEA 4751- 다솔이의 다이아몬드 장식

hyng·2022년 3월 16일
0

SWEA

목록 보기
53/78
post-custom-banner

배열을 하나 두고 각 문자 별로 다이아몬드로 배열 값을 변경해 주면 된다.

Code

import java.util.*;
class Solution
{
    static final int DY[] = {-1,0,1,0,-2,-1,0,1,2,1,0,-1};
    static final int DX[] = {0,-1,0,1,0,-1,-2,-1,0,1,2,1};

	public static void main(String args[]) throws Exception
	{
		Scanner sc = new Scanner(System.in);
        StringBuffer sb = new StringBuffer();


        int T = Integer.parseInt(sc.nextLine());
        for (int tc = 1; tc <= T; tc++) {
            String input = sc.nextLine();
            int len = input.length();

            int rowSize = 5;
            int colSize = len * 5 - (len - 1);

            char arr[][] = new char[rowSize][colSize];

            int y = 2;
            int x = 2;

            for(int i=0; i<len; i++){
                arr[y][x] = input.charAt(i);

                //다이아몬드 만들기
                createDiamond(0, 4, y, x, arr, '.');
                createDiamond(4, 12, y, x, arr, '#');
                x += 4;
            }

            for(int i=0; i<rowSize; i++){
                for(int j=0; j<colSize; j++){
                    if(arr[i][j] == 0)
                        sb.append('.');
                    else
                        sb.append(arr[i][j]);
                }
                sb.append("\n");
            }

        }
        System.out.println(sb);
    }

    private static void createDiamond(int s, int e, int y, int x, char[][] arr, char c) {
        for(int j = s; j< e; j++){
            int ny = y + DY[j];
            int nx = x + DX[j];

            arr[ny][nx] = c;

        }
    }

}
profile
공부하고 알게 된 내용을 기록하는 블로그
post-custom-banner

0개의 댓글