Algorithm/Jungol (도형만들기2)

[1641] 숫자삼각형

whereareyoung 2023. 10. 17. 14:28

문제

삼각형의 높이 n과 종류 m을 입력받은 후 다음과 같은 삼각형 형태로 출력하는 프로그램을 작성하시오.

< 처리조건 >

종류 1번의 숫자의 진행 순서는 처음에 왼쪽에서 오른쪽으로 진행 한 후 방향을 바꾸어서 이를 반복한다.

입력

삼각형의 크기 n(n의 범위는 100 이하의 홀수)과 종류 m(m은 1부터 3사이의 정수)을 입력받는다.

출력

위에서 언급한 3가지 종류를 입력에서 들어온 높이 n과 종류 m에 맞춰서 출력한다. 숫자사이는 공백으로 구분한다.

입력된 데이터가 주어진 범위를 벗어나면 "INPUT ERROR!"을 출력한다.


예제1 입력

7 3

 

예제1 출력

1
1 2
1 2 3
1 2 3 4
1 2 3
1 2
1

 

예제2 입력

3 2

 

예제2 출력

0 0 0 0 0
  1 1 1
    2

 

예제3 입력

5 1

 

예제3 출력

1
3 2
4 5 6
10 9 8 7
11 12 13 14 15


<입력 설계>

삼각형의 크기 n(n의 범위는 100 이하의 자연수)과 종류 m(m은 1부터 3사이의 자연수)을 입력받는다.

조건을 충족하지 못할경우 처리부분을 만든다. 

int n, m;
scanf("%d %d", &n, &m);

if (n > 100 || n % 2 == 0 || n < 1)
{
	printf("INPUT ERROR!");
	return 0;
}

if (m == 1) 
{
}
else if (m == 2) 
{
}
else if (m == 3) 
{
}
else 
{
    printf("INPUT ERROR!");
    return 0;
}

 

 

<출력 설계>

종류 1) 

if (m == 1) {
        int k = 0;
        for (int i = 1; i <= n; i++) {
            if (i % 2 == 0) {
                k += i;
            }
            for (int j = 0; j < i; j++) {
                if (i % 2 == 0) {
                    printf("%d ", k - j);
                }
                else {
                    printf("%d ", ++k);
                }
            }
            printf("\n");
        }
    }

종류 2) 

else if (m == 2) 
{
	for (int i = 0; i < n; i++) 
	{
		for (int j = 0; j < i * 2; j++) 
		{
			printf(" ");
		}
		for (int j = i * 2; j < n * 2 - 1; j++) 
		{
			printf("%d ", i);
		}
		printf("\n");
	}
}

종류 3) 

    else if (m == 3) {
        for (int i = 1; i <= n / 2; i++) {
            for (int j = 1; j <= i; j++) {
                printf("%d ", j);
            }
            printf("\n");
        }
        for (int i = n / 2 + 1; i > 0; i--) {
            for (int j = 1; j <= i; j++) {
                printf("%d ", j);
            }
            printf("\n");
        }
    }

 

출답

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>

int main() {
    int n, m;
    scanf("%d %d", &n, &m);

    if (n > 100 || n % 2 == 0 || n < 1) {
        printf("INPUT ERROR!");
        return 0;
    }

    if (m == 1) {
        int k = 0;
        for (int i = 1; i <= n; i++) {
            if (i % 2 == 0) {
                k += i;
            }
            for (int j = 0; j < i; j++) {
                if (i % 2 == 0) {
                    printf("%d ", k - j);
                }
                else {
                    printf("%d ", ++k);
                }
            }
            printf("\n");
        }
    }
    else if (m == 2) {
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < i * 2; j++) {
                printf(" ");
            }
            for (int j = i * 2; j < n * 2 - 1; j++) {
                printf("%d ", i);
            }
            printf("\n");
        }
    }
    else if (m == 3) {
        for (int i = 1; i <= n / 2; i++) {
            for (int j = 1; j <= i; j++) {
                printf("%d ", j);
            }
            printf("\n");
        }
        for (int i = n / 2 + 1; i > 0; i--) {
            for (int j = 1; j <= i; j++) {
                printf("%d ", j);
            }
            printf("\n");
        }
    }
    else {
        printf("INPUT ERROR!");
    }

    return 0;
}

'Algorithm > Jungol (도형만들기2)' 카테고리의 다른 글

[5397] 달팽이사각형 (reserved)  (0) 2023.10.17
[1707] 달팽이 사각형  (0) 2023.10.17
[1329] 별삼각형3  (1) 2023.10.17
[1719] 별삼각형2  (0) 2023.10.17
[1523] 별삼각형1  (0) 2023.10.17