본문 바로가기
반응형

Problem Solving232

[카카오 기출] 길 찾기 게임 https://programmers.co.kr/learn/courses/30/lessons/42892 코딩테스트 연습 - 길 찾기 게임 [[5,3],[11,5],[13,3],[3,5],[6,1],[1,3],[8,6],[7,2],[2,2]] [[7,4,6,9,1,8,5,2,3],[9,6,5,8,1,4,3,2,7]] programmers.co.kr class Node: def __init__(self, val = 0, left = None, right = None): self.val = val self.left = left self.right = right import collections import sys sys.setrecursionlimit(10**5) def solution(nodeinfo): dc.. 2021. 9. 9.
[카카오 기출] 후보키 https://programmers.co.kr/learn/courses/30/lessons/42890 코딩테스트 연습 - 후보키 [["100","ryan","music","2"],["200","apeach","math","2"],["300","tube","computer","3"],["400","con","computer","4"],["500","muzi","music","3"],["600","apeach","music","2"]] 2 programmers.co.kr 왤케 오래걸리고 어려웠을까.. 일단 버벅인 원인 중 하나가 for문을 너무 여러번 쓰다보니 내가 쓴 것마저 헷갈렸다는 것. 리스트 컴프리헨션을 잘 활용해야 코드 양도 줄고 이해도 더 쉬워질 것 같다. import collections imp.. 2021. 9. 9.
[분할 정복] 백준 10830번: 행렬 제곱 https://www.acmicpc.net/problem/10830 10830번: 행렬 제곱 크기가 N*N인 행렬 A가 주어진다. 이때, A의 B제곱을 구하는 프로그램을 작성하시오. 수가 매우 커질 수 있으니, A^B의 각 원소를 1,000으로 나눈 나머지를 출력한다. www.acmicpc.net import collections n, b = map(int, input().split()) a = [] for i in range(n): a.append(list(map(int, input().split()))) dct = collections.defaultdict(list) dct[1] = a def cross(m1, m2, n1, n2): result = [[0 for _ in range(n)] for _.. 2021. 9. 8.
[카카오 기출] 기둥과 보 설치 https://programmers.co.kr/learn/courses/30/lessons/60061 코딩테스트 연습 - 기둥과 보 설치 5 [[1,0,0,1],[1,1,1,1],[2,1,0,1],[2,2,1,1],[5,0,0,1],[5,1,0,1],[4,2,1,1],[3,2,1,1]] [[1,0,0],[1,1,1],[2,1,0],[2,2,1],[3,2,1],[4,2,1],[5,0,0],[5,1,0]] 5 [[0,0,0,1],[2,0,0,1],[4,0,0,1],[0,1,1,1],[1,1,1,1],[2,1,1,1],[3,1,1,1],[2,0,0,0],[1,1,1,0],[2,2,0,1]] [[ programmers.co.kr 너무 빡코딩이라 스트레쓰를 받는다. 맨정신엔 못푼다. def solution(n, .. 2021. 9. 7.
[카카오 기출] 가사 검색 https://programmers.co.kr/learn/courses/30/lessons/60060 코딩테스트 연습 - 가사 검색 programmers.co.kr 무식한 방법을 처음에 시도했다. word = 'apple'이라면 딕셔너리의 키로 '?????', '?pple', '??ple', '???le', '????e', 'appl?', 'app??', 'ap???', 'a????' 을 만들어서 이 value값에 1을 추가해준다. 이 방법은 정확성은 통과되지만 효율성은 통과하지 못한다. import collections def solution(words, queries): dct = collections.defaultdict(int) for word in words: temp = [x for x in .. 2021. 9. 7.
[카카오 기출] 자물쇠와 열쇠 https://programmers.co.kr/learn/courses/30/lessons/60059?language=python3 코딩테스트 연습 - 자물쇠와 열쇠 [[0, 0, 0], [1, 0, 0], [0, 1, 1]] [[1, 1, 1], [1, 1, 0], [1, 0, 1]] true programmers.co.kr def solution(key, lock): m = len(key) n = len(lock) def rotate(): rkey = [[0 for _ in range(m)] for _ in range(m)] for i in range(m): for j in range(m): rkey[j][-i+m-1] = key[i][j] return rkey for _ in range(4): # .. 2021. 9. 7.
반응형