[파이썬 기초 100제] 12강 반복 실행 구조
업데이트:
문제 71
71.
정수가 순서대로 입력된다.
(단, 개수는 알 수 없다.)
0이 아니면 입력된 정수를 출력하고, 0이 입력되면 출력을 중단해보자.
while( ), for( ) 등의 반복문을 사용할 수 없다.
입력 : 정수가 순서대로 입력된다.
7 4 2 3 0 1 5 6 9 10 8
출력 : 입력된 정수를 줄을 바꿔 하나씩 출력하는데, 0이 입력되면 종료한다. (0은 출력하지 않는다.)
7
4
2
3
TIP
원래 이 문제는 goto문을 이용해 풀도록 유도한 것인데 파이썬에서는 goto문을 제공하지 않으므로 함수를 이용하여 풀도록 한다.
파이썬에서는 do~while()과 같은 반복문도 제공하지 않는다.
파이썬에서는 함수를 이용하여 goto문처럼 사용하면 된다.
풀이
# 답
def goto(array, i):
if array[i] == 0:
return
print(array[i])
i += 1
goto(array, i)
array = list(map(int, input().split()))
goto(array, i = 0)
# 나의 답
def prt(arr, i):
if not arr[i]:
return
if arr[i]:
# 굳이 if문을 안써주어도 된다.
print(arr[i])
prt(arr, i + 1)
index = 0
a = map(int, input().split())
# list()로 감싸주어야 한다.
prt(a, index)
문제 72
72.
n개의 정수가 순서대로 입력된다.
(단 n의 최대 개수는 알 수 없다.)
n개의 입력된 정수를 순서대로 출력해보자.
while( ), for( ) 등의 반복문을 사용할 수 없다.
입력 : 첫 줄에 정수의 개수 n이 입력되고, 두 번째 줄에 n개의 정수가 공백을 두고 입력된다.
5
1 2 3 4 5
출력 : n개의 정수를 한 개씩 줄을 바꿔 출력한다.
1
2
3
4
5
TIP
리스트의 메소드인 reverse()는 내부 원소들을 거꾸로 재정렬해준다.
풀이
n = int(input())
number = list(map(int, input().split()))
# 방법 1
def goto(number, n, i):
if i == n: return
print( number[i] )
i += 1
goto(number, n, i)
goto(number, n, 0)
# 방법 2 : reverse()
number.reverse()
def goto(number, n):
print(number[n])
n -= 1
if n == -1: return
goto(number, n)
goto(number, n-1)
문제 73
73.
정수가 순서대로 입력된다.
(단, 개수는 알 수 없다.)
0이 아니면 입력된 정수를 출력하고, 0이 입력되면 출력을 중단해보자.
입력 : 정수가 순서대로 입력된다.
7 4 2 3 0 1 5 6 9 10 8
출력 : 입력된 정수를 줄을 바꿔 하나씩 출력하는데, 0이 입력되면 종료한다. (0은 출력하지 않는다.)
7
4
2
3
TIP
풀이
number = map(int, input().split())
# 방법 1
for element in number:
if element is not 0:
print(element)
continue # continue를 만나면 아래의 구문은 실행하지 않고 다음 반복으로 넘어간다.
break
# 방법 2
for value in number:
if value == 0: break
print(value)
문제 74
74.
정수(1 ~ 100) 1개가 입력되었을 때 카운트다운을 출력해보자.
입력 : 정수 1개가 입력된다. (1 ~ 100)
5
출력 : 1씩 줄이면서 한 줄에 하나씩 1이 될 때까지 출력한다.
5
4
3
2
1
TIP
풀이
count = int(input())
for i in range(count, 0, -1):
print(i)
문제 75
75.
정수(1 ~ 100) 1개가 입력되었을 때 카운트다운을 출력해보자.
입력 : 정수 1개가 입력된다. (1 ~ 100)
5
출력 : 1씩 줄이면서 한 줄에 하나씩 1이 될 때까지 출력한다.
4
3
2
1
0
TIP
풀이
count = int(input())
for i in range(count-1, -1, -1):
print(i)
문제 76
76.
영문자(a ~ z) 1개가 입력되었을 때 그 문자까지의 알파벳을 순서대로 출력해보자.
입력 : 영문자 1개가 입력된다. (a ~ z)
f
출력 : a부터 입력한 문자까지 순서대로 공백을 두고 출력한다.
a b c d e f
TIP
for()
아스키 코드를 이용하면 된다.
ord()
: 문자를 아스키 코드의 10진수로 변환 ex) ‘a’ » 97
chr()
: 10진수의 아스키 코드를 문자로 변환 ex) 97 » ‘a’
print()
함수의 두번째 파라미터인 end는 줄바꿈을 없애줄 수 있다. default값이 줄바꿈이다.
풀이
converter = ord(input())
for i in range(97, converter+1):
print(chr(i), end=' ')
문제 77
77.
정수(0 ~ 100) 1개를 입력받아 0부터 그 수까지 순서대로 출력해보자.
입력 : 정수 1개가 입력된다. (0 ~ 100)
4
출력 : 0부터 그 수까지 줄을 바꿔 한 개씩 출력한다.
0
1
2
3
4
TIP
while() or for()
풀이
count = int(input())
# 방법 1 : while()
i = 0
while count >= 0:
print(i)
i += 1
count -= 1
# 방법 1 : for()
for i in range(0, count+1):
print(i)
Notice: 이 게시물은 우리밋_woorimIT님의 유튜브를 참고하였습니다.
댓글남기기