강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

IJILKJ님의 프로필 이미지
IJILKJ

작성한 질문수

파이썬 알고리즘 문제풀이 입문(코딩테스트 대비)

8. 곳감(모래시계)

내장 라이브러리를 써서 풀어봤는데 질문이있습니다.

작성

·

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

김태원님의 프로필 이미지
김태원
지식공유자

참고로 작년에 삼성같은 경우 상시테스트에서 itertools 라이브러리를 사용못하게 한 적도 있습니다.

0

김태원님의 프로필 이미지
김태원
지식공유자

좋은 코드입니다. many 값을 회전 패턴에 의해서 나머지 값으로 처리한 게 매우 좋아 보입니다.

요즘은 대부분의 회사들이 내장함수를 사용하게 허락해줍니다. 못하게 할 때는 따로 공지를 합니다.

IJILKJ님의 프로필 이미지
IJILKJ

작성한 질문수

질문하기