네오는 평소 프로도가 비상금을 숨겨놓는 장소를 알려줄 비밀지도를 손에 넣었다. 그런데 이 비밀지도는 숫자로 암호화되어 있어 위치를 확인하기 위해서는 암호를 해독해야 한다. 다행히 지도 암호를 해독할 방법을 적어놓은 메모도 함께 발견했다.

네오가 프로도의 비상금을 손에 넣을 수 있도록, 비밀지도의 암호를 해독하는 작업을 도와줄 프로그램을 작성하라.
입력으로 지도의 한 변 크기 n 과 2개의 정수 배열 arr1, arr2가 들어온다.
원래의 비밀지도를 해독하여 '#', 공백으로 구성된 문자열 배열로 출력하라.
| 매개변수 | 값 | 
|---|---|
| n | 5 | 
| arr1 | [9, 20, 28, 18, 11] | 
| arr2 | [30, 1, 21, 17, 28] | 
| 출력 | ["#####","# # #", "### #", "# ##", "#####"] | 
| n | 6 | 
| arr1 | [46, 33, 33 ,22, 31, 50] | 
| arr2 | [27 ,56, 19, 14, 14, 10] | 
| 출력 | ["######", "### #", "## ##", " #### ", " #####", "### # "] | 
import java.util.*;
class Solution {
    public String[] solution(int n, int[] arr1, int[] arr2) {
        StringBuffer sb = new StringBuffer();
        String answer[] = new String[n];
        for(int i = 0; i < n; i++) {
            String s = "";
            String arr1Str = Integer.toString(arr1[i], 2);
            String arr2Str = Integer.toString(arr2[i], 2);
            
            for(int j = 0; j < n; j++) {
                if(arr1Str.length() < n) arr1Str = "0" + arr1Str;
                else if(arr2Str.length() < n) arr2Str = "0" + arr2Str;
            }
            for(int j = 0; j < n; j++) {
                if(arr1Str.charAt(j) == '0' && arr2Str.charAt(j) == '0') s += " ";
                else if(arr1Str.charAt(j) == '1') s += "#";
                else if(arr2Str.charAt(j) == '1') s += "#";
            }
            answer[i] = s;
        }
        return answer;
    }
}
class Solution {
  public String[] solution(int n, int[] arr1, int[] arr2) {
        String[] result = new String[n];
        for (int i = 0; i < n; i++) {
            result[i] = Integer.toBinaryString(arr1[i] | arr2[i]);
        }
        for (int i = 0; i < n; i++) {
            result[i] = String.format("%" + n + "s", result[i]);
            result[i] = result[i].replaceAll("1", "#");
            result[i] = result[i].replaceAll("0", " ");
        }
        return result;
    }
}
replaceAll 사용 .. 코드는 깔끔하지만 속도가 느리다.
class Solution {
    public String makeSharp(int n, int m) {
        if(n == 0) {
            if( m > 0) {
                String str = "";
                for(int i = 0; i < m; i++) {
                    str += " ";
                }
                return str;
            }
            else return "";
        }
        else {
            return n % 2 == 0 ? makeSharp(n/2, m-1) + " " : makeSharp(n/2, m-1) + "#"; 
        }
    }
    public String[] solution(int n, int [] arr1, int [] arr2) {
        String [] answer = new String[n];
        int [] secretMap = new int[n];
        for(int i = 0; i < n; i++) {
            secretMap[i] = arr1[i] | arr2[i];
            answer[i] = makeSharp(secretMap[i], n);
        }
        return answer;
    }
}
재귀 함수 사용