인프런 커뮤니티 질문&답변
내장 라이브러리를 써서 풀어봤는데 질문이있습니다.
작성
·
572
0
풀이를 보기전에 파이썬 내장라이브러리인 collections.deque를 이용하여 아래와 같은 함수를 만들어서 풀었습니다.
괜찮은 풀이인지 확인받고싶습니다.
그리고 실제 코딩테스트에서 collections, itertools같은 내장라이브러리를 사용해도되나요?
from collections import deque
def move_list(direct, many, l):
sub_q = deque()
q = deque(l)
if direct == left:
for _ in range(many):
sub_q.append(q.popleft())
return list(q+sub_q)
if direct == right:
for _ in range(n-many, n):
sub_q.appendleft(q.pop())
return list(sub_q+q)
left, right = 0, 1
n = int(input())
matrix = [list(map(int, input().split())) for _ in range(n)]
m = int(input())
for _ in range(m):
row, direct, many = map(int, input().split())
many = many % n
for i in range(n):
if i == row-1:
matrix[i] = move_list(direct, many, matrix[i])
s, e = 0, n-1
res = 0
for i in range(n):
for j in range(s, e+1):
res += matrix[i][j]
if i < n // 2:
s += 1
e -= 1
else:
s -= 1
e += 1
print(res)
답변 3
0
데크를 쓴 좋은 풀이법 올려주셔서 감사합니다!
한가지 궁금한 점이 있는데 many의 값을 n으로 나눈 나머지를 다시 many로 넣어준 코드가 어떤 기능을 하는지 디버깅을 해봐도 잘 이해가 되지 않아 부연 설명을 해주실 수 있을까 해서 질문 남깁니다.
0
0
김태원
지식공유자
좋은 코드입니다. many 값을 회전 패턴에 의해서 나머지 값으로 처리한 게 매우 좋아 보입니다.
요즘은 대부분의 회사들이 내장함수를 사용하게 허락해줍니다. 못하게 할 때는 따로 공지를 합니다.





