{"componentChunkName":"component---src-templates-blog-post-js","path":"/Algorithm/BOJ-18223-Python/","result":{"data":{"site":{"siteMetadata":{"title":"hyesungoh","author":"hyesungoh","siteUrl":"https://www.hyesungoh.xyz","comment":{"disqusShortName":"","utterances":"hyesungoh/blog"},"sponsor":{"buyMeACoffeeId":""}}},"markdownRemark":{"id":"6450ee0d-2fff-52a1-9cf3-8b044b0dbbc1","excerpt":"V개의 정점, E개의 간선, 들려야할 정점 P가 주어진다. 1부터 V까지의 최단거리와 1부터 P를 들려 V에 도착하는 최단거리가 같을 시 “SAVE HIM”을, 다를 시 “GOOD BYE”를 출력하는 문제. 첫 번째 풀이는 플로이드 와샬 방법을 이용하여 모든 정점으로부터의 최단거리를 계산한 후, 1부터 V까지의 값과 1부터 P까지의 값 + P부터 V까지의 값을 비교하여 풀었으나 시간초과 결과를 받게 되었다. 두 번째 풀이는 INF와 heap을 사용하는 다익스트라를 구현하여 1부터의 최단거리들, P…","html":"<p>V개의 정점, E개의 간선, 들려야할 정점 P가 주어진다. 1부터 V까지의 최단거리와 1부터 P를 들려 V에 도착하는 최단거리가 같을 시 “SAVE HIM”을, 다를 시 “GOOD BYE”를 출력하는 문제. 첫 번째 풀이는 플로이드 와샬 방법을 이용하여 모든 정점으로부터의 최단거리를 계산한 후, 1부터 V까지의 값과 1부터 P까지의 값 + P부터 V까지의 값을 비교하여 풀었으나 시간초과 결과를 받게 되었다. 두 번째 풀이는 INF와 heap을 사용하는 다익스트라를 구현하여 1부터의 최단거리들, P부터의 최단거리를 계산하여 위 공식을 대입해 풀었다.</p>\n<div class=\"gatsby-highlight\" data-language=\"python\"><pre class=\"language-python\"><code class=\"language-python\"><span class=\"token comment\"># import sys</span>\n<span class=\"token comment\"># INF = sys.maxsize</span>\n<span class=\"token comment\"># input = sys.stdin.readline</span>\n<span class=\"token comment\">#</span>\n<span class=\"token comment\"># def floyd(graph):</span>\n<span class=\"token comment\">#     for k in range(1, V+1):</span>\n<span class=\"token comment\">#         graph[k][k] = 0</span>\n<span class=\"token comment\">#         for i in range(1, V+1):</span>\n<span class=\"token comment\">#             for j in range(1, V+1):</span>\n<span class=\"token comment\">#                 graph[i][j] = min(graph[i][k] + graph[k][j], graph[i][j])</span>\n<span class=\"token comment\">#</span>\n<span class=\"token comment\">#</span>\n<span class=\"token comment\"># V, E, P = map(int, input().split())</span>\n<span class=\"token comment\"># graph = [[INF for _ in range(V+1)] for _ in range(V+1)]</span>\n<span class=\"token comment\">#</span>\n<span class=\"token comment\"># for _ in range(E):</span>\n<span class=\"token comment\">#     s, e, w = map(int, input().split())</span>\n<span class=\"token comment\">#     graph[s][e] = min(graph[s][e], w)</span>\n<span class=\"token comment\">#     graph[e][s] = min(graph[e][s], w)</span>\n<span class=\"token comment\">#</span>\n<span class=\"token comment\"># floyd(graph)</span>\n<span class=\"token comment\"># print(\"SAVE HIME\" if graph[1][V] == graph[1][P] + graph[P][V] else \"GOOD BYE\")</span>\n\n\n<span class=\"token keyword\">import</span> heapq\n<span class=\"token keyword\">import</span> sys\nINF <span class=\"token operator\">=</span> sys<span class=\"token punctuation\">.</span>maxsize\n<span class=\"token builtin\">input</span> <span class=\"token operator\">=</span> sys<span class=\"token punctuation\">.</span>stdin<span class=\"token punctuation\">.</span>readline\n\n\n<span class=\"token keyword\">def</span> <span class=\"token function\">dijkstra</span><span class=\"token punctuation\">(</span>start<span class=\"token punctuation\">)</span><span class=\"token punctuation\">:</span>\n    dist <span class=\"token operator\">=</span> <span class=\"token punctuation\">[</span>INF <span class=\"token keyword\">for</span> _ <span class=\"token keyword\">in</span> <span class=\"token builtin\">range</span><span class=\"token punctuation\">(</span>V<span class=\"token operator\">+</span><span class=\"token number\">1</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">]</span>\n    dist<span class=\"token punctuation\">[</span>start<span class=\"token punctuation\">]</span> <span class=\"token operator\">=</span> <span class=\"token number\">0</span>\n\n    q <span class=\"token operator\">=</span> <span class=\"token punctuation\">[</span><span class=\"token punctuation\">]</span>\n    heapq<span class=\"token punctuation\">.</span>heappush<span class=\"token punctuation\">(</span>q<span class=\"token punctuation\">,</span> <span class=\"token punctuation\">[</span><span class=\"token number\">0</span><span class=\"token punctuation\">,</span> start<span class=\"token punctuation\">]</span><span class=\"token punctuation\">)</span>\n\n    <span class=\"token keyword\">while</span> q<span class=\"token punctuation\">:</span>\n        w<span class=\"token punctuation\">,</span> n <span class=\"token operator\">=</span> heapq<span class=\"token punctuation\">.</span>heappop<span class=\"token punctuation\">(</span>q<span class=\"token punctuation\">)</span>\n\n        <span class=\"token keyword\">if</span> dist<span class=\"token punctuation\">[</span>n<span class=\"token punctuation\">]</span> <span class=\"token operator\">&lt;</span> w<span class=\"token punctuation\">:</span>\n            <span class=\"token keyword\">continue</span>\n\n        <span class=\"token keyword\">for</span> nn<span class=\"token punctuation\">,</span> tw <span class=\"token keyword\">in</span> graph<span class=\"token punctuation\">[</span>n<span class=\"token punctuation\">]</span><span class=\"token punctuation\">:</span>\n            nw <span class=\"token operator\">=</span> w <span class=\"token operator\">+</span> tw\n            <span class=\"token keyword\">if</span> dist<span class=\"token punctuation\">[</span>nn<span class=\"token punctuation\">]</span> <span class=\"token operator\">></span> nw<span class=\"token punctuation\">:</span>\n                dist<span class=\"token punctuation\">[</span>nn<span class=\"token punctuation\">]</span> <span class=\"token operator\">=</span> nw\n                heapq<span class=\"token punctuation\">.</span>heappush<span class=\"token punctuation\">(</span>q<span class=\"token punctuation\">,</span> <span class=\"token punctuation\">[</span>nw<span class=\"token punctuation\">,</span> nn<span class=\"token punctuation\">]</span><span class=\"token punctuation\">)</span>\n\n    <span class=\"token keyword\">return</span> dist\n\nV<span class=\"token punctuation\">,</span> E<span class=\"token punctuation\">,</span> P <span class=\"token operator\">=</span> <span class=\"token builtin\">map</span><span class=\"token punctuation\">(</span><span class=\"token builtin\">int</span><span class=\"token punctuation\">,</span> <span class=\"token builtin\">input</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">.</span>split<span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">)</span>\ngraph <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span>i<span class=\"token punctuation\">:</span> <span class=\"token punctuation\">[</span><span class=\"token punctuation\">]</span> <span class=\"token keyword\">for</span> i <span class=\"token keyword\">in</span> <span class=\"token builtin\">range</span><span class=\"token punctuation\">(</span>V<span class=\"token operator\">+</span><span class=\"token number\">1</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">}</span>\n<span class=\"token keyword\">for</span> _ <span class=\"token keyword\">in</span> <span class=\"token builtin\">range</span><span class=\"token punctuation\">(</span>E<span class=\"token punctuation\">)</span><span class=\"token punctuation\">:</span>\n    s<span class=\"token punctuation\">,</span> e<span class=\"token punctuation\">,</span> w <span class=\"token operator\">=</span> <span class=\"token builtin\">map</span><span class=\"token punctuation\">(</span><span class=\"token builtin\">int</span><span class=\"token punctuation\">,</span> <span class=\"token builtin\">input</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">.</span>split<span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">)</span>\n    graph<span class=\"token punctuation\">[</span>s<span class=\"token punctuation\">]</span><span class=\"token punctuation\">.</span>append<span class=\"token punctuation\">(</span><span class=\"token punctuation\">[</span>e<span class=\"token punctuation\">,</span> w<span class=\"token punctuation\">]</span><span class=\"token punctuation\">)</span>\n    graph<span class=\"token punctuation\">[</span>e<span class=\"token punctuation\">]</span><span class=\"token punctuation\">.</span>append<span class=\"token punctuation\">(</span><span class=\"token punctuation\">[</span>s<span class=\"token punctuation\">,</span> w<span class=\"token punctuation\">]</span><span class=\"token punctuation\">)</span>\n\n\ndist <span class=\"token operator\">=</span> dijkstra<span class=\"token punctuation\">(</span><span class=\"token number\">1</span><span class=\"token punctuation\">)</span>\ndist_p <span class=\"token operator\">=</span> dijkstra<span class=\"token punctuation\">(</span>P<span class=\"token punctuation\">)</span>\n<span class=\"token keyword\">print</span><span class=\"token punctuation\">(</span><span class=\"token string\">\"SAVE HIM\"</span> <span class=\"token keyword\">if</span> dist<span class=\"token punctuation\">[</span>V<span class=\"token punctuation\">]</span> <span class=\"token operator\">==</span> dist<span class=\"token punctuation\">[</span>P<span class=\"token punctuation\">]</span> <span class=\"token operator\">+</span> dist_p<span class=\"token punctuation\">[</span>V<span class=\"token punctuation\">]</span> <span class=\"token keyword\">else</span> <span class=\"token string\">\"GOOD BYE\"</span><span class=\"token punctuation\">)</span></code></pre></div>","frontmatter":{"title":"BOJ-18223 - Python","date":"March 03, 2021"}}},"pageContext":{"slug":"/Algorithm/BOJ-18223-Python/","previous":{"fields":{"slug":"/Algorithm/BOJ-1915-Python/"},"frontmatter":{"title":"BOJ-1915 - Python","category":"Algorithm","draft":false}},"next":{"fields":{"slug":"/Algorithm/프로그래머스-전화번호목록-Python/"},"frontmatter":{"title":"프로그래머스-전화번호목록 - Python","category":"Algorithm","draft":false}}}},"staticQueryHashes":["3128451518","3290666882"]}