※ 모든 문제의 저작권은 SW Expert 아카데미에 있습니다. 학습 기록용으로 문제시 삭제하겠습니다.
4869. [파이썬 S/W 문제해결 기본] 4일차 - 종이붙이기
어린이 알고리즘 교실의 선생님은 경우의 수 놀이를 위해, 그림처럼 가로x세로 길이가 10x20, 20x20인 직사각형 종이를 잔뜩 준비했다.
그리고 교실 바닥에 20xN 크기의 직사각형을 테이프로 표시하고, 이 안에 준비한 종이를 빈틈없이 붙이는 방법을 찾아보려고 한다. N이 30인 경우 다음 그림처럼 종이를 붙일 수 있다.
10의 배수인 N이 주어졌을 때, 종이를 붙이는 모든 경우를 찾으려면 테이프로 만든 표시한 영역을 몇 개나 만들어야 되는지 계산하는 프로그램을 만드시오. 직사각형 종이가 모자라는 경우는 없다.
입력_
첫 줄에 테스트 케이스 개수 T가 주어진다. 1≤T≤50
다음 줄부터 테스트 케이스 별로 N이 주어진다. 10≤N≤300, N은 10의 배수
3
30
50
70
출력_
각 줄마다 "#T" (T는 테스트 케이스 번호)를 출력한 뒤, 답을 출력한다.
#1 5
#2 21
#3 85
[문제 풀이]
# 재귀함수 사용
def paper_check(num):
if num == 10:
return 1
elif num == 20:
return 3
else:
return paper_check(num-10) + (paper_check(num-20) * 2)
# 테스트 케이스 입력
for t in range(int(input())):
# 각 문자열 리스트로 입력
n = int(input())
# 형식에 맞게 출력
print(f'#{t+1}', paper_check(n))
4866. [파이썬 S/W 문제해결 기본] 4일차 - 괄호검사
주어진 입력에서 괄호 {}, ()가 제대로 짝을 이뤘는지 검사하는 프로그램을 만드시오.
예를 들어 {( )}는 제대로 된 짝이지만, {( })는 제대로 된 짝이 아니다. 입력은 한 줄의 파이썬 코드일수도 있고, 괄호만 주어질 수도 있다.
정상적으로 짝을 이룬 경우 1, 그렇지 않으면 0을 출력한다.
print(‘{‘) 같은 경우는 입력으로 주어지지 않으므로 고려하지 않아도 된다.
입력_
첫 줄에 테스트 케이스 개수 T가 주어진다. (1≤T≤50)
다음 줄부터 테스트 케이스 별로 온전한 형태이거나 괄호만 남긴 한 줄의 코드가 주어진다.
3
print('{} {}'.format(1, 2))
N, M = map(int, input().split())
print('#{} {}'.format(tc, find())
출력_
각 줄마다 "#T" (T는 테스트 케이스 번호)를 출력한 뒤, 답을 출력한다.
#1 1
#2 1
#3 0
[문제 풀이]
# 테스트 케이스 입력
for t in range(int(input())):
# 각 문자열 리스트로 입력
str_lst = list(map(str, input()))
lst = []
cnt = 1
for word in str_lst:
# 열린 괄호면 리스트에 추가
if word == '(' or word == '{':
lst.append(word)
# 닫힌 괄호일때
elif word == ')' or word == '}':
# 리스트 길이가 0이면 카운트는 0으로 초기화 및 종료
if len(lst) == 0:
cnt = 0
break
# 리스트에서 뺀 것이
p = lst.pop()
# 닫힌 괄호면서 맞는 열린 괄호가 아니면 카운트는 0으로 초기화
if p != '(' and word == ')':
cnt = 0
elif p != '{' and word == '}':
cnt = 0
# 리스트내 요소가 있으면 카운트 0으로 초기화
if lst:
cnt = 0
print(f'#{t+1}', cnt)
4871. [파이썬 S/W 문제해결 기본] 4일차 - 그래프 경로
V개 이내의 노드를 E개의 간선으로 연결한 방향성 그래프에 대한 정보가 주어질 때, 특정한 두 개의 노드에 경로가 존재하는지 확인하는 프로그램을 만드시오.
두 개의 노드에 대해 경로가 있으면 1, 없으면 0을 출력한다.
예를 들어 다음과 같은 그래프에서 1에서 6으로 가는 경로를 찾는 경우, 경로가 존재하므로 1을 출력한다.
노드번호는 1번부터 존재하며, V개의 노드 중에는 간선으로 연결되지 않은 경우도 있을 수 있다.
입력_
첫 줄에 테스트 케이스 개수 T가 주어진다. 1≤T≤50
다음 줄부터 테스트 케이스의 첫 줄에 V와 E가 주어진다. 5≤V≤50, 4≤E≤1000
테스트케이스의 둘째 줄부터 E개의 줄에 걸쳐, 출발 도착 노드로 간선 정보가 주어진다.
E개의 줄 이후에는 경로의 존재를 확인할 출발 노드 S와 도착노드 G가 주어진다.
3
6 5
1 4
1 3
2 3
2 5
4 6
1 6
7 4
1 6
2 3
2 6
3 5
2 5
9 9
2 6
4 7
5 7
1 5
2 9
3 9
4 8
5 3
7 8
1 9
출력_
각 줄마다 "#T" (T는 테스트 케이스 번호)를 출력한 뒤, 답을 출력한다.
#1 1
#2 1
#3 1
[문제 풀이]
# 재귀함수로 정의
def dfs(node):
# 리스트에 해당노드를 트루로 초기화
visit[node] = True
# v번 반복하며 다음(인접) 노드에서 방문을 했냐 안했냐를 판별하기 위함
for next in range(1, v+1):
# if visit[next] == False and graph[node][next] == 1:
if not visit[next] and graph[node][next]:
dfs(next)
# 테스트 케이스 입력
for t in range(int(input())):
# 노드최대 수와 간선 수 입력
v, e = map(int, input().split())
# 방문을 했는 지 알기위해 사용하며 v만큼 false로 초기화
visit = [False for _ in range(v+1)]
# (v,v)의 0행렬로 만들어 입력받을 노드들을 저장하기 위해 사용
graph = [[0 for _ in range(v+1)] for _ in range(v+1)]
# 입력받은 간선 수만큼 반복하며 입력받은 노드들의 위치를 1로 초기화
for _ in range(e):
# 각 연결되는 노드들을 입력
u, e = map(int, input().split())
# 해당 행과 열에 맞게 원래 0이였던 값을 1로 초기화
graph[u][e] = 1
# 알고싶은 시작과 끝 노드 입력
s, g = map(int, input().split())
# 함수 사용
dfs(s)
# 만약 방문을 했다면 형식에 맞게 1을 출력
if visit[g] == 1:
print(f'#{t+1}', 1)
else: print(f'#{t+1}', 0)
4873. [파이썬 S/W 문제해결 기본] 4일차 - 반복문자 지우기
문자열 s에서 반복된 문자를 지우려고 한다. 지워진 부분은 다시 앞뒤를 연결하는데, 만약 연결에 의해 또 반복문자가 생기면 이부분을 다시 지운다.
반복문자를 지운 후 남은 문자열의 길이를 출력 하시오. 남은 문자열이 없으면 0을 출력한다.
다음은 CAAABBA에서 반복문자를 지우는 경우의 예이다.
CAAABBA 연속 문자 AA를 지우고 C와 A를 잇는다.
CABBA 연속 문자 BB를 지우고 A와 A를 잇는다.
CAA 연속 문자 AA를 지운다.
C 1글자가 남았으므로 1을 리턴한다.
입력_
첫 줄에 테스트 케이스 개수 T가 주어진다. (1≤T≤50)
다음 줄부터 테스트 케이스의 별로 길이가 1000이내인 문자열이 주어진다.
3
ABCCB
NNNASBBSNV
UKJWHGGHNFTCRRCTWLALX
출력_
각 줄마다 "#T" (T는 테스트 케이스 번호)를 출력한 뒤, 답을 출력한다.
#1 1
#2 4
#3 11
[문제 풀이]
# 테스트 케이스 입력
for t in range(int(input())):
# 리스트로 입력
str_lst = list(map(str, input()))
# 스택으로 이용할 리스트 생성
lst = []
# 입력받은 만큼 반복
for word in str_lst:
# 처음일 경우
if len(lst) == 0:
lst.append(word)
else:
# 스택에 저장된 마지막 단어와 현재 단어 비교 후
if lst[-1] == word:
# 같으면 스택에서 pop
lst.pop()
else:
# 다르면 추가
lst.append(word)
# 형식에 맞게 출력
print(f'#{t+1}', len(lst))