문제
원하는 구구단의 범위를 입력받아 해당 구간의 구구단을 출력하는 프로그램을 작성하시오.
[처리조건]
(1) 구간의 처음과 끝을 입력받는다.
(2) 입력된 구간은 반드시 처음 입력 값이 끝의 입력 값보다 작아야 하는 것은 아니다.
즉, 입력된 구간의 범위는 증가하거나 감소하는 순서 그대로 출력되어야 한다.
입력
구구단의 시작 범위 s,와 끝 범위 e를 입력받는다.(s와 e는 2부터 9사이의 정수)
하나의 결과가 출력되면 프로그램을 종료한다.
출력
시작 범위와 끝 범위사이의 구구단을 출력하되 모든 값과 부호 사이는 공백으로 구분하여 아래 출력 예와 같이 줄을 맞추어 출력해야 한다.
구구단 사이는 3개의 공백으로 구분한다.
데이터의 크기가 주어진 범위를 벗어날 경우는 "INPUT ERROR!"를 출력하고 s와 e를 다시 입력받는다.
예제1 입력
4 3
예제1 출력
4 * 1 = 4 3 * 1 = 3
4 * 2 = 8 3 * 2 = 6
4 * 3 = 12 3 * 3 = 9
4 * 4 = 16 3 * 4 = 12
4 * 5 = 20 3 * 5 = 15
4 * 6 = 24 3 * 6 = 18
4 * 7 = 28 3 * 7 = 21
4 * 8 = 32 3 * 8 = 24
4 * 9 = 36 3 * 9 = 27
예제2 입력
5 7
예제2 출력
5 * 1 = 5 6 * 1 = 6 7 * 1 = 7
5 * 2 = 10 6 * 2 = 12 7 * 2 = 14
5 * 3 = 15 6 * 3 = 18 7 * 3 = 21
5 * 4 = 20 6 * 4 = 24 7 * 4 = 28
5 * 5 = 25 6 * 5 = 30 7 * 5 = 35
5 * 6 = 30 6 * 6 = 36 7 * 6 = 42
5 * 7 = 35 6 * 7 = 42 7 * 7 = 49
5 * 8 = 40 6 * 8 = 48 7 * 8 = 56
5 * 9 = 45 6 * 9 = 54 7 * 9 = 63
예제3 입력
1 6
11 5
9 6
예제3 출력
INPUT ERROR!
INPUT ERROR!
9 * 1 = 9 8 * 1 = 8 7 * 1 = 7 6 * 1 = 6
9 * 2 = 18 8 * 2 = 16 7 * 2 = 14 6 * 2 = 12
9 * 3 = 27 8 * 3 = 24 7 * 3 = 21 6 * 3 = 18
9 * 4 = 36 8 * 4 = 32 7 * 4 = 28 6 * 4 = 24
9 * 5 = 45 8 * 5 = 40 7 * 5 = 35 6 * 5 = 30
9 * 6 = 54 8 * 6 = 48 7 * 6 = 42 6 * 6 = 36
9 * 7 = 63 8 * 7 = 56 7 * 7 = 49 6 * 7 = 42
9 * 8 = 72 8 * 8 = 64 7 * 8 = 56 6 * 8 = 48
9 * 9 = 81 8 * 9 = 72 7 * 9 = 63 6 * 9 = 54
처리조건
(1) 구간의 처음과 끝을 입력받는다.
(2) 입력된 구간은 반드시 처음 입력 값이 끝의 입력 값보다 작아야 하는 것은 아니다.
- 입력된 구간의 범위는 증가하거나 감소하는 순서 그대로 출력되어야 한다.
- 3, 5 가 입력 될 수 도 있고 5, 3 이 입력 될 수 도 있다는 뜻이며 내림차순, 오름차순이 둘다 가능하다는 뜻이다.
입력형식
구구단의 시작 범위 s, 와 끝 범위 e를 입력받는다. (s와 e는 2부터 9사이의 정수)
하나의 결과가 출력되면 프로그램을 종료한다
<입력의 설계>
- 입력을 받아서 값이 정상적인 범위일 경우 입력종료
- 범위가 벗어날 경우 에러 출력 ~ 종료시까지 무한 반복
while(1)
{
scanf("%d %d", &s, &e);
if(s>=2 && s<=9 && e>=2 &&e<=9) break;
printf("INPUT ERROR!\n");
}
출력형식
시작 범위와 끝 범위사이의 구구단을 출력하되 모든 값과 부호 사이는 공백으로 구분하여 아래 출력 예와 같이 줄을 맞추어 출력해야 한다. 구구단 사이는 3개의 공백으로 구분한다.
데이터의 크기가 주어진 범위를 벗어날 경우는 "INPUT ERROR!" 를 출력하고 s와 e를 다시 입력받는다.
- s나 e둘중하나가 2 ~ 9를 벗어날 경우 다시 입력받는다는 부분이 문제가 되는것
<출력의 설계>
- s가 클 경우와 그렇지 않은 경우 구분해서 출력
* i, j 를 잘 생각해야함
- i 가 1-9까지 먼저 돌아야 함
- j 에서 생각할 것 1. 오름차 순일 경우 2. 내림차 순일 경우
if(s>e)
{
for(i = 1; i<= 9; i++)
{
for(j = s; j >= e; j--)
{
printf("%d * %d = %2d ", j, i, j*i);
}
printf("\n");
}
}
else
{
for(i = 1; i<= 9; i++)
{
for(j = s; j <= e; j++)
{
printf("%d * %d = %2d ", j, i, j*i);
}
printf("\n");
}
}
설계특징
while문으로 처리 / if문을 반복해 처리 등 다양한 방법이 있기 때문에 가장 최적화에 가까운 답을 연구
제출답변
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
int s, e;
while (1)
{
scanf("%d %d", &s, &e);
if (s >= 2 && s <= 9 && e >= 2 && e <= 9) break;
printf("INPUT ERROR!\n");
}
if (s > e)
{
for (int i = 1; i <= 9; i++)
{
for (int j = s; j >= e; j--)
{
printf("%d * %d = %2d ", j, i, j * i);
}
printf("\n");
}
}
else
{
for (int i = 1; i <= 9; i++)
{
for (int j = s; j <= e; j++)
{
printf("%d * %d = %2d ", j, i, j * i);
}
printf("\n");
}
}
return 0;
}
'Algorithm > Jungol (도형만들기1)' 카테고리의 다른 글
[2046] 숫자사각형4 (0) | 2023.09.12 |
---|---|
[1304] 숫자사각형3 (0) | 2023.09.12 |
[1856] 숫자사각형2 (0) | 2023.09.12 |
[1303] 숫자사각형1 (0) | 2023.09.12 |
[1341] 구구단2 (0) | 2023.09.12 |