{"componentChunkName":"component---src-templates-blog-post-js","path":"/Algorithm/BOJ-1717-Python/","result":{"data":{"site":{"siteMetadata":{"title":"hyesungoh","author":"hyesungoh","siteUrl":"https://www.hyesungoh.xyz","comment":{"disqusShortName":"","utterances":"hyesungoh/blog"},"sponsor":{"buyMeACoffeeId":""}}},"markdownRemark":{"id":"178d7802-f8a1-5a34-8006-63ba66f34e9a","excerpt":"n개의 노드가 있을 때 각 노드들이 연결되어 있는 지 여부를 출력 및 합연산을 하는 유니온 파인드 문제. 기존 유니온 파인드로 풀 수 있는 문제들을 플로이드 와샬, DFSBFS 등의 방법으로 풀었으나 유니온 파인드 방법도 알아두면 좋을 것 같아 공부해보았다. 유니온 파인드는 주어진 노드 또는 집합을 합하는 Union과 노드의 루트 노드가 무엇인 지 반환하는 Find로 나뉜다. 자세한 사항은 주석을 참고. 해당 문제는 간단한 유니온 파인드의 구현으로 풀었다.","html":"<p>n개의 노드가 있을 때 각 노드들이 연결되어 있는 지 여부를 출력 및 합연산을 하는 유니온 파인드 문제. 기존 유니온 파인드로 풀 수 있는 문제들을 플로이드 와샬, DFSBFS 등의 방법으로 풀었으나 유니온 파인드 방법도 알아두면 좋을 것 같아 공부해보았다. 유니온 파인드는 주어진 노드 또는 집합을 합하는 Union과 노드의 루트 노드가 무엇인 지 반환하는 Find로 나뉜다. 자세한 사항은 주석을 참고. 해당 문제는 간단한 유니온 파인드의 구현으로 풀었다.</p>\n<div class=\"gatsby-highlight\" data-language=\"python\"><pre class=\"language-python\"><code class=\"language-python\"><span class=\"token keyword\">import</span> sys\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<span class=\"token keyword\">def</span> <span class=\"token function\">find</span><span class=\"token punctuation\">(</span>node<span class=\"token punctuation\">)</span><span class=\"token punctuation\">:</span>\n    <span class=\"token comment\"># 현재 노드가 루트 노드일 시</span>\n    <span class=\"token keyword\">if</span> node <span class=\"token operator\">==</span> parent<span class=\"token punctuation\">[</span>node<span class=\"token punctuation\">]</span><span class=\"token punctuation\">:</span>\n        <span class=\"token comment\"># 루트 노드 값을 반환</span>\n        <span class=\"token keyword\">return</span> node\n\n    <span class=\"token comment\"># 루트 노드가 아닐 시 재귀적으로 탐색</span>\n    p <span class=\"token operator\">=</span> find<span class=\"token punctuation\">(</span>parent<span class=\"token punctuation\">[</span>node<span class=\"token punctuation\">]</span><span class=\"token punctuation\">)</span>\n    <span class=\"token comment\"># 루트 노드를 현재 node 값에 저장</span>\n    parent<span class=\"token punctuation\">[</span>node<span class=\"token punctuation\">]</span> <span class=\"token operator\">=</span> p\n    <span class=\"token keyword\">return</span> p <span class=\"token comment\"># 해당 루트 노드 값을 반환</span>\n\n    <span class=\"token comment\"># 루트 노드가 아닐 시 탐색한 후 할당, 반환하는 과정을 경로 압축 최적화라고 한다</span>\n    <span class=\"token comment\"># return find(parent[u])와 같이 작성시 경로 압축 최적화가 안되었다고 할 수 있는데</span>\n    <span class=\"token comment\"># 이는 단순히 배열에 할당하지 않기 때문인가 ?</span>\n    <span class=\"token comment\"># 아무튼 사용 이유\u001d는 한 쪽으로 치우쳐진 트리일 때 걸리는 시간이라고 한다.</span>\n    <span class=\"token comment\"># 문제를 더 풀어가며 이해해야할 부분 같다.</span>\n\n\n<span class=\"token keyword\">def</span> <span class=\"token function\">union</span><span class=\"token punctuation\">(</span>a<span class=\"token punctuation\">,</span> b<span class=\"token punctuation\">)</span><span class=\"token punctuation\">:</span>\n    <span class=\"token comment\"># a, b의 루트 노드를 찾는다.</span>\n    parent_a <span class=\"token operator\">=</span> find<span class=\"token punctuation\">(</span>a<span class=\"token punctuation\">)</span>\n    parent_b <span class=\"token operator\">=</span> find<span class=\"token punctuation\">(</span>b<span class=\"token punctuation\">)</span>\n\n    <span class=\"token comment\"># 루트노드가 갖지 않을 시 b의 루트 노드에 a 루트 노드 값을 저장</span>\n    <span class=\"token comment\"># a의 루트 노드에 b 루트 노드 값을 저장해도 된다.</span>\n    <span class=\"token keyword\">if</span> parent_a <span class=\"token operator\">!=</span> parent_b<span class=\"token punctuation\">:</span>\n        parent<span class=\"token punctuation\">[</span>parent_b<span class=\"token punctuation\">]</span> <span class=\"token operator\">=</span> parent_a\n\n\nn<span class=\"token punctuation\">,</span> m <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<span class=\"token comment\"># 각 노드의 루트 노드를 저장할 배열</span>\n<span class=\"token comment\"># 처음에는 자기 자신을 루트 노드로 생성</span>\nparent <span class=\"token operator\">=</span> <span class=\"token punctuation\">[</span>i <span class=\"token keyword\">for</span> i <span class=\"token keyword\">in</span> <span class=\"token builtin\">range</span><span class=\"token punctuation\">(</span>n<span class=\"token operator\">+</span><span class=\"token number\">1</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">]</span>\n\n<span class=\"token keyword\">for</span> _ <span class=\"token keyword\">in</span> <span class=\"token builtin\">range</span><span class=\"token punctuation\">(</span>m<span class=\"token punctuation\">)</span><span class=\"token punctuation\">:</span>\n    c<span class=\"token punctuation\">,</span> a<span class=\"token punctuation\">,</span> b <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    <span class=\"token keyword\">if</span> c <span class=\"token operator\">==</span> <span class=\"token number\">0</span><span class=\"token punctuation\">:</span>\n        union<span class=\"token punctuation\">(</span>a<span class=\"token punctuation\">,</span> b<span class=\"token punctuation\">)</span>\n    <span class=\"token keyword\">else</span><span class=\"token punctuation\">:</span>\n        parent_a <span class=\"token operator\">=</span> find<span class=\"token punctuation\">(</span>a<span class=\"token punctuation\">)</span>\n        parent_b <span class=\"token operator\">=</span> find<span class=\"token punctuation\">(</span>b<span class=\"token punctuation\">)</span>\n        <span class=\"token keyword\">print</span><span class=\"token punctuation\">(</span><span class=\"token string\">\"YES\"</span> <span class=\"token keyword\">if</span> parent_a <span class=\"token operator\">==</span> parent_b <span class=\"token keyword\">else</span> <span class=\"token string\">\"NO\"</span><span class=\"token punctuation\">)</span></code></pre></div>","frontmatter":{"title":"BOJ-1717 - Python","date":"February 05, 2021"}}},"pageContext":{"slug":"/Algorithm/BOJ-1717-Python/","previous":{"fields":{"slug":"/Algorithm/BOJ-1850-Python/"},"frontmatter":{"title":"BOJ-1850 - Python","category":"Algorithm","draft":false}},"next":{"fields":{"slug":"/Algorithm/BOJ-1976-Python/"},"frontmatter":{"title":"BOJ-1976 - Python","category":"Algorithm","draft":false}}}},"staticQueryHashes":["3128451518","3290666882"]}