문제

예제를 보고 규칙을 유추한 뒤에 별을 찍어 보세요.

입력

첫째 줄에 N(1 ≤ N ≤ 100)이 주어진다.

출력

첫째 줄부터 2×N-1번째 줄까지 차례대로 별을 출력한다.

풀이

2442번과 2443을 결합하면 됩니다.

첫번째 for 반복문은 윗쪽 삼각형을 그리는 반복문입니다. i가 0부터 n까지 증가하고, 빈 공간 스페이스를 n-1-i 만큼, 별을 2*i 만큼 찍습니다.

두번째 for 반복문은 아랫쪽 삼각형을 그리는 반복문입니다. i가 n-1부터 0까지 줄어듭니다. 빈 공간 스페이스를 n-i만큼, 별을 i*2-1만큼 찍어서 삼각형을 만듭니다.

두 삼각형을 붙여서 꽉 찬 다이아몬드같은 별을 이룹니다!

#include <stdio.h>

int main() {
    int n;
    scanf("%d", &n);
    for (int i = 0; i < n; i++) {
        for (int k = 0; k < n-1-i; k++) {
            printf(" ");
        }
        for (int j = 0; j <= (i * 2); j++) {
            printf("*");
        }
        printf("\\n");
    }
    for (int i = n-1; i > 0; i--) {
        for (int k = n-i; k > 0; k--) {
            printf(" ");
        }
        for (int j = i * 2 - 1; j > 0; j--) {
            printf("*");
        }
        printf("\\n");
    }

}

Screenshot 2024-04-03 at 12.38.25 AM.png