
문제
소리가 컴퓨터에 저장될 때에는 디지털 데이터화 되어 저장된다.
마이크를 통해 1초에 적게는 수십 번, 많게는 수만 번 소리의 강약을 체크해
그 값을 정수값으로 바꾸고, 그 값을 저장해 소리를 파일로 저장할 수 있다.
값을 저장할 때에는 비트를 사용하는 정도에 따라 세세한 녹음 정도를 결정할 수 있고,
좌우(스테레오) 채널로 저장하면 2배… 5.1채널이면 6배의 저장공간이 필요하고,
녹음 시간이 길면 그 만큼 더 많은 저장공간이 필요하다.
1초 동안 마이크로 소리강약을 체크하는 수를 h
(헤르쯔, Hz 는 1초에 몇 번? 체크하는가를 의미한다.)
한 번 체크한 결과를 저장하는 비트 b
(2비트를 사용하면 0 또는 1 두 가지, 16비트를 사용하면 65536가지..)
좌우 등 소리를 저장할 트랙 개수인 채널 c
(모노는 1개, 스테레오는 2개의 트랙으로 저장함을 의미한다.)
녹음할 시간 s가 주어질 때,
필요한 저장 용량을 계산하는 프로그램을 작성해보자.
실제로 일반적인 CD 음질(44.1KHz, 16bit, 스테레오)로 1초 동안 저장하려면
44100 * 16 * 2 * 1 bit의 저장공간이 필요하다.
이렇게 녹음하는 방식을 PCM(Pulse Code Modulation) 방법이라고 하는데,
압축하지 않은 순수한(raw) 소리 데이터 파일은 대표적으로 *.wav 가 있다.
**
8 bit(비트) = 1byte(바이트) // 8bit=1Byte
1024 Byte(210 byte) = 1KB(킬로 바이트) // 1024bit=1KB
1024 KB(210 KB) = 1MB(메가 바이트)
1024 MB(210 MB) = 1GB(기가 바이트)
1024 GB(210 GB) = 1TB(테라 바이트)
h는 48,000이하, b는 32이하(단, 8의배수), c는 5이하, s는 6,000이하의 자연수이다.
단, 소수점 둘째 자리에서 반올림해 첫째 자리까지 출력하고 MB를 공백을 두고 출력한다.
44100 16 2 10
1.7 MB
풀이
#include <stdio.h>
int main()
{
long long int h, b, c, s, storage;
scanf("%lld %lld %lld %lld", &h, &b, &c, &s);
storage = h * b * c * s;
printf("%.1lf MB", (double)storage/8/1024/1024);
return 0;
}
긴 문제설명, 생소한 소리파일 배경지식과 long long int 자료형 사용을 해야해서 정답율이 낮은 문제이다.
문제 설명에 나와있듯이, 저장공간은 h*b*c*s 비트만큼 필요하다.
우리가 구해야 하는 값은 메가바이트 값이므로, h*b*c*s를 8로 나누어 byte로 환산, 1024로 나누어 KB로 환산, 1024로 나누어 MB로 환산해주면 된다.
단위가 커지므로 long long int를 사용하여야 하며, 소수를 담을 수 있는 자료형으로 형변환 및 반올림도 잊지 말고 해주자.
'Algorithm > 코드업' 카테고리의 다른 글
[Codeup] 1167 : 두 번째 수 (C언어) (0) | 2024.05.30 |
---|---|
[Codeup] 1165 : 축구의 신 1 (C언어) (0) | 2024.05.29 |
[Codeup] 1045 : 정수 2개 입력받아 자동 계산하기 (0) | 2024.05.26 |
[Codeup] 1046 : 정수 3개 입력받아 합과 평균 출력하기 (C언어) (0) | 2024.05.26 |
[Codeup] 1038 : 정수 2개 입력받아 합 출력하기1 (C언어) (0) | 2024.05.26 |