Algorithm/Jungol (도형만들기2)

[1719] 별삼각형2

whereareyoung 2023. 10. 17. 14:10

문제

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

다음은 n이 5인 경우의 예시이다.

 

입력

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

출력

위에서 언급된 4가지 종류를 입력에서 들어온 높이 n과 종류 m에 맞춰서 출력한다.

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

'*'과 '*' 사이에는 공백이 없다.


예제1 입력

5 1

 

예제1 출력

*
**
***
**
*

 

예제2 입력

7 4

 

예제2 출력

****
 ***
  **
   *
   **
   ***
   ****


<입력 설계>

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

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

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

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

 

<출력 설계>

종류 1) 

if (m == 1)
	{
		for (i = 0; i < n / 2; i++)
		{
			for (j = 0; j <= i; j++)
			{
				printf("*");
			}
			printf("\n");
		}
		for (i = 0; i < n / 2 + 1; i++)
		{
			for (j = n / 2 - i; j >= 0; j--)
			{
				printf("*");
			}
			printf("\n");
		}
	}

종류 2)

else if (m == 2)
	{
		for (i = 0; i < n / 2; i++)
		{
			for (j = 0; j < n / 2 - i; j++)
			{
				printf(" ");
			}
			for (j = 0; j <= i; j++)
			{
				printf("*");
			}
			printf("\n");
		}

		for (i = 0; i < n / 2 + 1; i++)
		{
			for (j = 0; j < i; j++)
			{
				printf(" ");
			}
			for (j = n / 2 - i; j >= 0; j--)
			{
				printf("*");
			}
			printf("\n");
		}
	}

종류 3)

else if (m == 3)
	{
		for (i = 0; i < n / 2; i++)
		{
			for (j = 0; j < i; j++)
			{
				printf(" ");
			}
			for (j = 0; j < n - i * 2; j++)
			{
				printf("*");
			}
			printf("\n");
		}

		for (i = 0; i <= n / 2; i++)
		{
			for (j = 0; j < n / 2 - i; j++)
			{
				printf(" ");
			}
			for (j = 0; j <= i * 2; j++)
			{
				printf("*");
			}
			printf("\n");
		}
	}

종류 4)

else if (m == 4)
	{
		for (i = 0; i < n / 2; i++)
		{
			for (j = 0; j < i; j++)
			{
				printf(" ");
			}
			for (j = 0; j <= n / 2 - i; j++)
			{
				printf("*");
			}
			printf("\n");
		}

		for (i = 0; i < n / 2 + 1; i++)
		{
			for (j = 0; j < n / 2; j++)
			{
				printf(" ");
			}
			for (j = 0; j <= i; j++)
			{
				printf("*");
			}
			printf("\n");
		}
	}

 

출답

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>

int main()
{
	int n, m; 
    int i, j, k;

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

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

	if (m == 1)
	{
		for (i = 0; i < n / 2; i++)
		{
			for (j = 0; j <= i; j++)
			{
				printf("*");
			}
			printf("\n");
		}
		for (i = 0; i < n / 2 + 1; i++)
		{
			for (j = n / 2 - i; j >= 0; j--)
			{
				printf("*");
			}
			printf("\n");
		}
	}

	else if (m == 2)
	{
		for (i = 0; i < n / 2; i++)
		{
			for (j = 0; j < n / 2 - i; j++)
			{
				printf(" ");
			}
			for (j = 0; j <= i; j++)
			{
				printf("*");
			}
			printf("\n");
		}

		for (i = 0; i < n / 2 + 1; i++)
		{
			for (j = 0; j < i; j++)
			{
				printf(" ");
			}
			for (j = n / 2 - i; j >= 0; j--)
			{
				printf("*");
			}
			printf("\n");
		}
	}

	else if (m == 3)
	{
		for (i = 0; i < n / 2; i++)
		{
			for (j = 0; j < i; j++)
			{
				printf(" ");
			}
			for (j = 0; j < n - i * 2; j++)
			{
				printf("*");
			}
			printf("\n");
		}

		for (i = 0; i <= n / 2; i++)
		{
			for (j = 0; j < n / 2 - i; j++)
			{
				printf(" ");
			}
			for (j = 0; j <= i * 2; j++)
			{
				printf("*");
			}
			printf("\n");
		}
	}

	else if (m == 4)
	{
		for (i = 0; i < n / 2; i++)
		{
			for (j = 0; j < i; j++)
			{
				printf(" ");
			}
			for (j = 0; j <= n / 2 - i; j++)
			{
				printf("*");
			}
			printf("\n");
		}

		for (i = 0; i < n / 2 + 1; i++)
		{
			for (j = 0; j < n / 2; j++)
			{
				printf(" ");
			}
			for (j = 0; j <= i; j++)
			{
				printf("*");
			}
			printf("\n");
		}
	}
	else
		printf("INPUT ERROR!");

	return 0;
}

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

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