프로그래머스 합승 택시 요금 파이썬
1. 문제 https://programmers.co.kr/learn/courses/30/lessons/72413 코딩테스트 연습 - 합승 택시 요금 6 4 6 2 [[4, 1, 10], [3, 5, 24], [5, 6, 2], [3, 1, 41], [5, 1, 24], [4, 6, 50], [2, 4, 66], [2, 3, 22], [1, 6, 25]] 82 7 3 4 1 [[5, 7, 9], [4, 6, 4], [3, 6, 1], [3, 2, 3], [2, 1, 6]] 14 6 4 5 6 [[2,6,6], [6,3,7], [4,6,7], [6,5,11], [2,5,12], [5,3,20], [2,4 programmers.co.kr 2. 풀이 다익스트라 3. 구현 import math import hea..
2021. 8. 14.
프로그래머스: 순위 python, 파이썬
1. 문제 https://programmers.co.kr/learn/courses/30/lessons/49191# 코딩테스트 연습 - 순위 5 [[4, 3], [4, 2], [3, 2], [1, 2], [2, 5]] 2 programmers.co.kr 2. 풀이 이 분의 아이디어를 읽고 구현했다. 내 언어로 설명해보자면, 1) 주어진 값 넣기: 먼저 n*n 배열을 만들고, 배열[이긴사람][진사람]에 1(이김) 배열[진사람][이긴사람]에 -1 짐을 넣는다. 여기서 중요한 건 몇등이냐가 아니라 모든 다른 사람에 대해 내 결과를 가지고 있는 사람이 몇사람이냐는 것이다. 2) 배열을 채운다: 이제 배열을 순회하면서 A가 B를 이겼다면 B에게 진 사람들은 A에게 모두 졌을 것이라고 생각하고 이것을 채워넣는다. 마..
2021. 7. 3.
프로그래머스: 가장 먼 노드 python, 파이썬
1. 문제 https://programmers.co.kr/learn/courses/30/lessons/49189#qna 코딩테스트 연습 - 가장 먼 노드 6 [[3, 6], [4, 3], [3, 2], [1, 3], [1, 2], [2, 4], [5, 2]] 3 programmers.co.kr 2. 풀이 bfs 3. 구현 from collections import deque def solution(n, edge): answer = 0 dic={} for s,e in edge: if s in dic: dic[s].append(e) else: dic[s]=[e] if e in dic: dic[e].append(s) else: dic[e]=[s] q=deque() visit = {} dist=0 q.appen..
2021. 7. 2.