[백준,BOJ 2446] 별 찍기-9( JAVA 구현)
코테/백준 온라인 저지(BOJ)

[백준,BOJ 2446] 별 찍기-9( JAVA 구현)

반응형

 

-해법

  별 찍기 문제-9이다. 솔직히 별 찍기 문제는 무언가 특별한 기술이 필요한 것이 아니라, 예제 출력의 모양을 본 후 규칙성을 찾아 구현해야 하는 것 같다. 이번 문제의 경우에는 눈에 딱 봐도 앞 뒤로 한 개씩 빈칸이 증가하는 것을 알 수 있다. 1번째 줄에서 앞 뒤로 0개의 빈칸, 2번째 줄에서 앞 뒤로 1개의 빈칸.... 식으로 가는 규칙성을 찾았으면 이제 이를 토대로 구현해보면 된다. 필자는 보통 중앙을 포함해 윗부분을 구현하고 아랫부분을 별도로 구현한다.

 

//윗부분 구현

for(int i=0;i<n;i++) { // 빈 칸의 개수가 +1씩 증가하므로 0부터 4까지 반복해준다. 
			for(int j=1;j<2*n;j++) { // 열의 개수는 동일하므로 고정한다.
				if(j ==2 * n -i) break; // 이는 출력형식 오류를 방지하기 위해서 수행해준다. 
                						// 즉, 별을 다 찍으면 반복문을 벗어나 다음 행으로 간다.
				if(j > 0+i && j<2*n-i) { // 해당 범위안에서만 별을 찍어준다.
					System.out.print("*");
				}else // 나머지는 공백 처리
					System.out.print(" ");
			}
			System.out.println();
}

 

// 아랫부분 구현

for(int i=1;i<n;i++) { // 아랫 부분의 반복 범위의 표현을 위해 1~4반복
			for(int j=1;j<2*n;j++) { // 열은 고정
				if(j>n+i) break; // 마찬가지로 마지막 별을 찍은 다음 반복은 수행하지 않는다.
				if(j>= n-i && j<=n+i) { // 해당 범위에 별을 찍기 각 범위가 양쪽에서 1씩 증가하므로
                						// 한 줄이 넘어갈 때 마다 2개씩 별이 더 찍히게 된다.
					System.out.print("*");
				}else // 나머지는 공백처리
					System.out.print(" ");
			}
		System.out.println();
	}
반응형