"/>

코드업 기초 – [기초-종합] 1078~1085번까지 해설,정답

1078[기초-종합] 짝수 합 구하기

문제 설명
정수 한 개를 입력받아 1 부터 그 수까지 짝수의 합을 구해보자.

입력
정수 한 개가 입력된다.
(0 ~ 100)

출력
1부터 입력된 수까지 짝수의 합을 출력한다.

입력 예시 예시 복사
5

출력 예시
6

도움말
어떤 형태의 반복문을 사용하던지 가능하다.

while( ) {…}, do {…} while( );, for(…; …; …) {…} 등의 반복문은

형태만 다르고, 똑같은 성능을 발휘한다. 필요에 따라 편리한 것으로 골라 사용하면 된다.

예시
//아래의 예는 홀수일 경우만 합해 그 결과를 출력한다.
int sum=0;
int i, n;
scanf(“%d”, &n);
for(i=1; i<=n; i++)
{
if(i%2==1) sum=sum+i;
}

정답

1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include<stdio.h>
int main()
{
    int sum = 0;
    int i, n;
    scanf(“%d”, &n);
    for (i = 1; i <= n; i++)
    {
        if (i % 2 == 0)
            sum += i;
    }
    printf(“%d”, sum);
    return 0;
}

1079[기초-종합] 원하는 문자 입력할 때까지 반복 출력하기

문제 설명
영문자 q 가 입력될 때까지 계속 반복하는 프로그램을 작성해보자.

입력
영문자가 한 개씩 계속 입력된다.

출력
영문자 q가 입력될 때까지 입력한 문자를 줄을 바꿔 계속 출력한다.

입력 예시 예시 복사
x b k d l q g a c

출력 예시
x
b
k
d
l
q

정답

1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include<stdio.h>
int main()
{
    char a;
    do
    {
        scanf(“%c “, &a);
        printf(“%c\n”, a);
    } while (a != ‘q’);
    return 0;
}

1080[기초-종합] 언제까지 더해야할까?

문제 설명
1, 2, 3 … 을 계속 더해나갈때, 그 합이 입력한 정수보다 크거나 같을 때까지,
(0 ~ 1000)

계속 합하는 프로그램을 작성해보자.

즉, 1부터 n까지 정수를 계속 합해 간다고 할 때, 어디까지 합해야 같거나 넘어서는지 알아보고자하는 문제이다.

입력
어느 정도까지 합을 계산할 지,

정수 한개를 입력받는다.

출력
1, 2, 3, 4, 5 … 계속 더해가다가,

입력된 정수보다 커지거나 같아지는 경우, 마지막에 더해진 정수를 출력한다.

입력 예시 예시 복사
55

출력 예시
10

정답

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <stdio.h>
int main(){
    int n, i = 1;
    int sum = 0;
    scanf(“%d”, &n);
    while (1)
    {
        sum += i;
        if (n <= sum)
        {
            printf(“%d\n”, i);
            break;
        }
        i++;
    }
    return 0;
}

1081[기초-종합] 언제까지 더해야할까?

문제 설명
1부터 n까지, 1부터 m 까지 숫자가 적힌 색이 서로 다른 주사위 2개를 던졌을 때,

나올 수 있는 모든 경우를 출력해보자.

문제 설명
1부터 n까지, 1부터 m 까지 숫자가 적힌 색이 서로 다른 주사위 2개를 던졌을 때,

나올 수 있는 모든 경우를 출력해보자.

입력
서로 다른 주사위의 면의 개수 n, m이 공백을 두고 입력된다.

(단, n, m은 10이하의 자연수)

출력
나올 수 있는 주사위의 숫자가 한 세트씩 줄을 바꿔 모두 출력된다.

첫 수는 n, 두번째 수는 m으로 고정해 출력하도록 한다.

입력 예시 예시 복사
2 3

출력 예시
1 1
1 2
1 3
2 1
2 2
2 3

도움말
중첩의 원리…
반복 실행구조도 조건 실행구조와 마찬가지로 중첩의 원리가 적용된다.

반복 실행구조를 중첩해면 원하는 반복구조를 다양하게 만들어낼 수 있다.

예시
int i, j;
int n=3, m=6;
for(i=1; i<=n; i++)
{
for(j=1; j<=m; j++)
{
printf(“%d %d “, i, j);
}
}

의 코드는 바깥쪽의 i가 1부터 n까지 로 바뀌는 각각의 동안에
안쪽의 j가 1부터 m까지 변하며 출력된다.

중첩 반복되는 코드 블럭의 내용이 논리적으로 1단위 이기 때문에 코드 블럭 기호를 생략하면 아래와 같이도 작성가능하다.

int i, j;
int n=3, m=6
for(i=1; i<=n; i++)
for(j=1; j<=m; j++)
printf(“%d %d “, i, j);

반복 실행구조를 사용할 때에는 반복횟수를 기록해 두기 위해 i, j와 같은 변수를 선언해 사용해야 한다.

정답

1
2
3
4
5
6
7
8
9
10
11
12
13
#include <stdio.h>
int main(){
    int n, m, n1, m1;
    scanf(“%d %d”, &n, &m);
    for (int n1 = 1; n1 <= n; n1++) {
        for (int m1 = 1; m1 <= m; m1++) {
            printf(“%d %d\n”, n1,m1);
        }
    }
    return 0;
}

1082[기초-종합] 주사위를 2개 던지면?

문제 설명
16진수(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F)를 배운 경곽이는

16진수끼리 곱하는 16진수 구구단?에 대해서 궁금해졌다.

A, B, C, D, E, F 중 하나가 입력될 때, 1부터 F까지 곱한 16진수 구구단의 내용을 출력해보자.
(단, A ~ F 까지만 입력된다.)

입력
16진수로 한자리 수가 입력된다.
(단, A ~ F 까지만 입력된다.)

출력
입력한 16진수에 1~F까지 순서대로 곱한,

16진수 구구단을 줄을 바꿔 출력한다.

계산 결과도 16진수로 출력해야 한다.

입력 예시 예시 복사
B

출력 예시
B*1=B
B*2=16
B*3=21
B*4=2C
B*5=37
B*6=42
B*7=4D
B*8=58
B*9=63
B*A=6E
B*B=79
B*C=84
B*D=8F
B*E=9A
B*F=A5

정답

1
2
3
4
5
6
7
8
9
#include <stdio.h>
int main(){
    int i, j;
    scanf(“%x”, &i);
    for (int j = 1; j < 16; j++) {
        printf(“%X*%X=%X\n”, i, j, i*j);
    }
    return 0;
}

1083[기초-종합] 3 6 9 게임의 왕이 되자!

문제 설명
3 6 9 게임을 하던 경곽이는 3 6 9 게임에서 잦은 실수로 계속해서 벌칙을 받게 되었다.

3 6 9 게임의 왕이 되기 위한 마스터 프로그램을 작성해 보자.

입력
10보다 작은 정수 한 개가 입력된다.
(1 ~ 10)

출력
1 부터 그 수까지 순서대로 공백을 두고 수를 출력하는데,

3 또는 6 또는 9인 경우 그 수 대신 영문 대문자 X 를 출력한다.

입력 예시 예시 복사
9

출력 예시
1 2 X 4 5 X 7 8 X

도움말
중첩의 원리
반복 실행구조 안에 선택 실행구조를 자유롭게 중첩할 수 있다.

예시
int i;
for(i=1; i<=100; i++) //1부터 100까지 반복
{
if(i%3==0 || i%5==0) printf(“%d “, i); //3또는 5의 배수인 경우 그 수 출력
}

정답

1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <stdio.h>
int main(){
    int i, j;
    scanf(“%d”, &i);
    for (int j=1; j <= i; j++) {
        if (j % 3 == 0) {
            printf(“X “);
        }
        else {
            printf(“%d “, j);
        }
    }
    return 0;
}

** 3 6 9 게임이란?
여러 사람이 순서를 정해 순서대로 수를 부르는 게임이다.

만약 3, 6, 9 가 들어간 수를 불러야 하는 상황이라면, 그 수대신 “박수” 등을 친다.

예를 들어 33 까지 진행했다면? “짝짝”과 같이 박수를 두번 치는 형식이다.

1084[기초-종합] 물감만들기

문제 설명
빨강(red), 녹색(green), 파랑(blue) 물감을 섞어 여러 가지 물감을 만들어 내려고한다.

빨강(r), 녹색(g), 파랑(b) 물감의 종류(농도에 따라 0~ n-1 까지 n가지의 농도를 만들 수 있다.)가 주어질 때,

주어진 물감들을 농도를 다르게 섞어 만들 수 있는 모든 물감의 정보(r g b)와 그 최대 개수를 계산해보자.

입력
빨녹파(r, g, b) 각 물감의 종류(농도) 개수가 공백을 사이에 두고 입력된다.
(0 ~ 128)

예를 들어 3 3 3 은 각 색에 대해서 0~2까지 3가지 물감이 있음을 의미한다.

출력
만들 수 있는 물감의 정보를 오름차순(계단을 올라가는 순, 12345… abcde…, 가나다라마…)으로 줄을 바꿔 모두 출력하고,

마지막에 그 개수를 출력한다.

입력 예시 예시 복사
2 2 2

출력 예시
0 0 0
0 0 1
0 1 0
0 1 1
1 0 0
1 0 1
1 1 0
1 1 1
8

도움말

예시

int i, j, k, c = 0;
int r, g, b;

scanf ( “% d % d % d”, & r, & g, & b);

for (i = 0; i

정답

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <stdio.h>
int main () {
    int r, g, b;
    int i, j, k, sum = 0;
    scanf ( “% d % d % d”, & r, & g, & b);
    
    for (i = 0; i <r; i ++) {
        for (j = 0; j <g; j ++) {
            for (k = 0; k <b; k ++) {
                printf ( “% d % d % d \ n”, i, j, k);
                sum ++;
            }
        }
    }
    printf ( “% d \ n”, 합계);
    0을 반환;
}

 

1085[기초-종합] 소리 파일 저장용량 계산하기

문제 설명
소리가 컴퓨터에 저장될 때에는 디지털 데이터화 되어 저장된다.

마이크를 통해 1초에 적게는 수십번 많게는 수만번 소리의 강약을 체크해 정수값으로 바꾸고,

정수값으로 저장될 때에는 비트를 사용하는 정도에 따라 세세한 녹음 정도를 저장할 수 있고,

좌우(스테레오)로 저장하면 2배… 5.1채널이면 6배… 의 저장공간이 필요하고

녹음 시간이 길면 그 시간만큼 저장공간이 필요하다.

1초 동안 마이크로 소리강약을 체크하는 수를 h (헤르쯔, Hz 는 1초에 몇 번? 체크하는 가를 의미한다.)

한 번 체크한 결과를 저장하는 비트 b(2비트를 사용하면 0 또는 1 두가지, 16비트를 사용하면 0~255가지.. 중 비슷한 것으로 저장)

좌우 등 소리를 저장할 트랙 개수인 채널 c(모노는 1개, 스테레오는 2개의 트랙으로 저장함을 의미한다.)

녹음할 시간 s가 주어질 때, 필요한 저장 용량을 계산하는 프로그램을 작성해보자.

실제로
일반적인 CD 음질(44.1KHz, 16bit, 스테레오)로 1초 동안 저장하려면
44100 * 16 * 2 * 1 bit의 저장공간이 필요하다.

이렇게 녹음하는 방식을 PCM(Pulse Code Modulation) 방법이라고 하는데, 압축하지 않은 순수한(raw) 소리 데이터 파일은 대표적으로 *.wav 가 있다.

**
8bit(비트) = 1byte(바이트) // 8bit=1Byte
1024Byte(2^10 byte) = 1KB(킬로 바이트)
1024KB(2^10 KB) = 1MB(메가 바이트)
1024MB(2^10 MB) = 1GB((기가 바이트)
….

입력
h, b, c, s 가 공백을 두고 입력된다.
(단, h는 48,000이하의 자연수, b는 32이하의 자연수(단, 8의배수), c는 5이하의 자연수, s는 모두 정수이이고 6,000이하의 자연수이다.)

출력
필요한 저장 공간을 MB 단위로 바꾸어 출력한다.
(단, 소수점 둘째 자리에서 반올림해 첫 째 자리까지 출력하고 단위 MB를 공백을 두고 출력한다.)

입력 예시 예시 복사
44100 16 2 10

출력 예시
1.7 MB

정답

1
2
3
4
5
6
7
8
9
10
11
12
13
#include <stdio.h>
int main () {
    int h, b, c, s; 
    두 번 결과;
    scanf ( “% d % d % d % d”, & h, & b, & c, & s);
    결과 = h * b * c * s / 8;
    결과 = 결과 / 1024;
    결과 = 결과 / 1024;
    printf ( “% .1f MB”, 결과);
    0을 반환;
}

8bit(비트) = 1byte(바이트) // 8bit=1Byte
1024Byte(2^10 byte) = 1KB(킬로 바이트)
1024KB(2^10 KB) = 1MB(메가 바이트)
1024MB(2^10 MB) = 1GB((기가 바이트)

댓글 남기기

Scroll Up