칸토어 집합은 0과 1사이의 실수로 이루어진 집합으로, 구간 [0, 1]에서 시작해서 각 구간을 3등분하여 가운데 구간을 반복적으로 제외하는 방식으로 만든다.
전체 집합이 유한이라고 가정하고, 다음과 같은 과정을 통해서 칸토어 집합의 근사를 만들어보자.
N
개 있는 문자열에서 시작한다.예를 들어, N
=3인 경우, 길이가 27인 문자열로 시작한다.
---------------------------
여기서 가운데 문자열을 공백으로 바꾼다.
--------- ---------
남은 두 선의 가운데 문자열을 공백으로 바꾼다.
--- --- --- ---
한번 더
- - - - - - - -
모든 선의 길이가 1이면 멈춘다. N
이 주어졌을 때, 마지막 과정이 끝난 후 결과를 출력하는 프로그램을 작성하시오.
입력을 여러 줄로 이루어져 있다. 각 줄에 N
이 주어진다. 파일의 끝에서 입력을 멈춘다. N
은 0보다 크거나 같고, 12보다 작거나 같은 정수이다.
입력으로 주어진 N
에 대해서, 해당하는 칸토어 집합의 근사를 출력한다.
0
1
3
2
-
- -
- - - - - - - -
- - - -
ICPC > Regionals > North America > Mid-Atlantic Regional > 2002 Mid-Atlantic Regional Programming Contest G번
-문제를 번역한 사람: baekjoon
import java.util.Scanner;
public class Code4779 {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
while(sc.hasNext()){
int N=sc.nextInt();
System.out.println(line(N));
}
}
public static String line(int n){
StringBuilder answer=new StringBuilder();
if(n==0){
return "-";
}
StringBuilder previous=new StringBuilder(line(n-1));
//`-`저장
int len=previous.length();
answer.append(previous);
answer.append(" ".repeat(len));
answer.append(previous);
return answer.toString();
}
}
처음부터 하나하나 쪼개려고 하니 복잡했던 것 같다.
그래서 재귀함수를 이용해서 0일때는 -
그리고 그 이후는 각각 이전 값 + 길이만큼의 공백+다시 이전값으로 진행했다.