1089 : [기초-종합] 수 나열하기1 


어떤 규칙에 따라 수를 순서대로 나열한 것을 수열(series)이라고 한다.

예를 들어
1 4 7 10 13 16 19 22 25 ... 은
1부터 시작해 이전에 만든 수에 3을 더해 다음 수를 만든 수열이다.
이러한 것을 수학에서는 앞뒤 수들의 차이가 같다고 하여

등차(차이가 같다의 한문 말) 수열이라고 한다.
수열을 알게 된 영일이는 갑자기 궁금해졌다.

"그럼.... 123번째 나오는 수는 뭘까?"

영일이는 프로그램을 만들어 더 큰 수도 자동으로 계산하고 싶어졌다.

시작 값(a), 등차(d), 몇 번째인지를 나타내는 정수(n)가 입력될 때
n번째 수를 출력하는 프로그램을 만들어보자.

 

정답

a,d,n=input().split(' ')
a=int(a)
d=int(d)
n=int(n)
c=1

while True:

    if c >= n:
       print(a)
       break
    else:
        a=a+d
        c=c+1

 

모범 소스

a,d,n=input().split()

A=int(a)
D=int(d)
N=int(n)

for i in range(N-1) :
    A = A + D

print(A)

 

 


CodeUp 기초 100제 : https://codeup.kr/problemsetsol.php?psid=23

 1088 : [기초-종합] 3의 배수는 통과?(설명)


1부터 입력한 정수까지 1씩 증가시켜 출력하는 프로그램을 작성하되,
3의 배수인 경우는 출력하지 않도록 만들어보자.

예를 들면,
1 2 4 5 7 8 10 11 13 14 ...
와 같이 출력하는 것이다.


참고
반복문 안에서 continue;가 실행되면 그 아래의 내용을 건너뛰고, 다음 반복을 수행한다.
즉, 다음 반복으로 넘어가는 것이다.

예시
for(i=1; i<=n; i++) //1부터 시작해 n까지 1씩 증가시키면서 반복한다.
{
if(i%2==0)
continue; //짝수라면? 아래 부분은 건너뛰고! 계속~
printf("%d ", i); //결국 짝수가 아닐 때에만 출력된다.
}

 

정답

a=input()
a=int(a)

for i in range(1,a+1):
    if i % 3 == 0:
        continue
    else:
        print(i,end=' ')

 

 


CodeUp 기초 100제 : https://codeup.kr/problemsetsol.php?psid=23

 1087 : [기초-종합] 여기까지! 이제 그만~(설명)


1, 2, 3 ... 을 순서대로 계속 더해나갈 때,
그 합이 입력한 정수보다 작을 동안만 계속 더하는 프로그램을 작성해보자.

즉, 1부터 n까지 정수를 계속 더한다고 할 때,
어디까지 더해야 입력한 수보다 같거나 커지는지 알아보고자 하는 문제이다.

하지만, 이번에는 그 때의 합을 출력해야 한다.

예를 들어 57을 입력하면
1+2+3+...+8+9+10=55에 다시 11을 더해 66이 될 때,
그 값 66이 출력되어야 한다.


참고
조건문이나 반복문의 코드블록 안에서 break;가 실행되면
가장 가까운 반복 코드블록 구역의 밖으로 빠져나간다.


예시
int n, i, s=0;
scanf("%d", &n);
for(i=1; ; i++) //for 반목문에서 가운데의 조건이 빠진 경우 무한 반복된다.
{
s+=i;
if(s>=n)
break; //참이면, 가장 가까운 반복 코드블록의 밖으로 빠져나간다.
} //break; 가 실행되면 반복을 중단하고 여기로 빠져 나온다.
printf("%d", s);

무한 반복이 되는 코드는
while(1) {...}, do {...}while(1); 등도 가능하다.
0이 아니면 모두 참(true)으로 인식되기 때문이다.

 

정답

a=input()
a=int(a)
b=0

for i in range(1,a+1):
    b=b+i
    if b >= a:
        break
        
print(b)

 

모범 소스

a=input()

n=int(a)

s=0
i=1
while s<n :
   s+=i
   i+=1

print(s)

 

 


CodeUp 기초 100제 : https://codeup.kr/problemsetsol.php?psid=23

 1086 : [기초-종합] 그림 파일 저장용량 계산하기(설명)


이미지가 컴퓨터에 저장될 때에도 디지털 데이터화 되어 저장된다.

가장 기본적인 방법으로는 그림을 구성하는 한 점(pixel, 픽셀)의 색상을
빨강(r), 초록(g), 파랑(b)의 3가지의 빛의 세기 값으로 따로 변환하여 저장하는 것인데,

예를 들어 r, g, b 각 색에 대해서 8비트(0~255, 256가지 가능)씩을 사용한다고 하면,

한 점의 색상은 3가지 r, g, b의 8비트+8비트+8비트로 총 24비트로 표현해서
총 2^24 가지의 서로 다른 빛의 색깔을 사용할 수 있는 것이다.

그렇게 저장하는 점을 모아 하나의 큰 이미지를 저장할 수 있게 되는데,
1024 * 768 사이즈에 각 점에 대해 24비트로 저장하면 그 이미지를 저장하기 위한
저장 용량을 계산할 수 있다.

이렇게 이미지의 원래(raw) 데이터를 압축하지 않고 그대로 저장하는 대표적인 이미지 파일이
*.bmp 파일이며, 비트로 그림을 구성한다고 하여 비트맵 방식 또는 래스터 방식이라고 한다.

이미지의 가로 해상도 w, 세로 해상도 h, 한 픽셀을 저장하기 위한 비트 b 가 주어질 때,
압축하지 않고 저장하기 위해 필요한 저장 용량을 계산하는 프로그램을 작성해 보자.


예를 들어
일반적인 1024 * 768 사이즈(해상도)의 각점에 대해
24비트(rgb 각각 8비트씩 3개)로 저장하려면 1024 * 768 * 24 bit의 저장 용량이 필요하다.

실제 그런지 확인하고 싶다면, 간단한 그림 편집/수정 프로그램을 통해 확인할 수 있다.


**
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(테라 바이트)

 

정답

a,b,c=input().split(' ')
a=int(a)
b=int(b)
c=int(c)

d=a*b*c
e=(((d / 8) / 1024) / 1024)

print('%.2f MB' %e)

 

 


CodeUp 기초 100제 : https://codeup.kr/problemsetsol.php?psid=23

 1085 : [기초-종합] 소리 파일 저장용량 계산하기(설명)


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

마이크를 통해 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(테라 바이트)

 

정답

a,b,c,d=input().split(' ')
a=int(a)
b=int(b)
c=int(c)
d=int(d)

k=a * b * c * d
su=((k / 8) / 1024)/ 1024

print('%.1f MB' %su)

 

 


CodeUp 기초 100제 : https://codeup.kr/problemsetsol.php?psid=23

 튜플

 

튜플 이름=(요소1, 요소2, ...)

 

튜플의 기본 구조입니다.

 

튜플는 소괄호 ()를 사용하여 감싸줍니다.

 

a=(1,2,3)
b=('aa','bb')
c=('aaa',1,2)
d=1,2

튜플 안의 요소는 서로 같은 형식이지 않아도 괜찮습니다.


튜플의 값은 한 번 만들면 바꿀 수 없습니다.
바꾸거나 삭제하려고 하면 에러가 발생합니다.

 

a=(1,2,3,4,5)

# 출력>>1
print(a[0])

# 출력>>4
print(a[0]+a[2])

# 출력>>5
print(a[-1])

튜플의 index는 0부터 시작합니다.


a[-1]은 튜플의 마지막 요소의 값을 의미합니다.

 

a=(1,2,3,4,5)

# 출력>>(1, 2)
print(a[0:2])

# 출력>>(1, 2)
print(a[:2])

# 출력>>(3, 4, 5)
print(a[2:])

튜플에서 슬라이싱은 사용 가능합니다.

 

a[0:2] : 튜플 a의 첫 번째 요소부터 세 번째 요소 전까지의 값을 나타냅니다.

a[:2] : 튜플 a의 첫 번째 요소부터 세 번째 요소 전까지의 값을 나타냅니다.

a[2:] : 튜플 a의 세 번째 요소부터 마지막 요소까지의 값을 나타냅니다.

+ Recent posts