Download free for 30 days
Sign in
Upload
Language (EN)
Support
Business
Mobile
Social Media
Marketing
Technology
Art & Photos
Career
Design
Education
Presentations & Public Speaking
Government & Nonprofit
Healthcare
Internet
Law
Leadership & Management
Automotive
Engineering
Software
Recruiting & HR
Retail
Sales
Services
Science
Small Business & Entrepreneurship
Food
Environment
Economy & Finance
Data & Analytics
Investor Relations
Sports
Spiritual
News & Politics
Travel
Self Improvement
Real Estate
Entertainment & Humor
Health & Medicine
Devices & Hardware
Lifestyle
Change Language
Language
English
Español
Português
Français
Deutsche
Cancel
Save
Submit search
EN
AI
Uploaded by
AtCoder Inc.
PDF, PPTX
194,169 views
Union find(素集合データ構造)
Union find(素集合データ構造)の解説です
Education
◦
Read more
27
Save
Share
Embed
Embed presentation
Download
Download as PDF, PPTX
1
/ 18
2
/ 18
3
/ 18
4
/ 18
5
/ 18
6
/ 18
7
/ 18
8
/ 18
9
/ 18
10
/ 18
11
/ 18
12
/ 18
13
/ 18
14
/ 18
15
/ 18
Most read
16
/ 18
17
/ 18
Most read
18
/ 18
Most read
More Related Content
PDF
プログラミングコンテストでのデータ構造
by
Takuya Akiba
PDF
プログラミングコンテストでの動的計画法
by
Takuya Akiba
PDF
プログラミングコンテストでのデータ構造 2 ~動的木編~
by
Takuya Akiba
PDF
最大流 (max flow)
by
HCPC: 北海道大学競技プログラミングサークル
PPTX
動的計画法を極める!
by
HCPC: 北海道大学競技プログラミングサークル
PDF
Binary indexed tree
by
HCPC: 北海道大学競技プログラミングサークル
PDF
実践・最強最速のアルゴリズム勉強会 第一回 講義資料(ワークスアプリケーションズ & AtCoder)
by
AtCoder Inc.
PDF
RMQ クエリ処理
by
HCPC: 北海道大学競技プログラミングサークル
プログラミングコンテストでのデータ構造
by
Takuya Akiba
プログラミングコンテストでの動的計画法
by
Takuya Akiba
プログラミングコンテストでのデータ構造 2 ~動的木編~
by
Takuya Akiba
最大流 (max flow)
by
HCPC: 北海道大学競技プログラミングサークル
動的計画法を極める!
by
HCPC: 北海道大学競技プログラミングサークル
Binary indexed tree
by
HCPC: 北海道大学競技プログラミングサークル
実践・最強最速のアルゴリズム勉強会 第一回 講義資料(ワークスアプリケーションズ & AtCoder)
by
AtCoder Inc.
RMQ クエリ処理
by
HCPC: 北海道大学競技プログラミングサークル
What's hot
PDF
プログラミングコンテストでのデータ構造 2 ~平衡二分探索木編~
by
Takuya Akiba
PDF
色々なダイクストラ高速化
by
yosupo
PDF
グラフネットワーク〜フロー&カット〜
by
HCPC: 北海道大学競技プログラミングサークル
PDF
プログラミングコンテストでの乱択アルゴリズム
by
Takuya Akiba
PDF
直交領域探索
by
okuraofvegetable
PDF
明日使えないすごいビット演算
by
京大 マイコンクラブ
PDF
ウェーブレット木の世界
by
Preferred Networks
PDF
様々な全域木問題
by
tmaehara
PDF
Convex Hull Trick
by
HCPC: 北海道大学競技プログラミングサークル
PDF
二部グラフの最小点被覆と最大安定集合と最小辺被覆の求め方
by
Kensuke Otsuki
PDF
勉強か?趣味か?人生か?―プログラミングコンテストとは
by
Takuya Akiba
PPTX
AtCoder Beginner Contest 034 解説
by
AtCoder Inc.
PDF
深さ優先探索による塗りつぶし
by
AtCoder Inc.
PPTX
モデル高速化百選
by
Yusuke Uchida
PDF
競技プログラミングにおけるコードの書き方とその利便性
by
Hibiki Yamashiro
PPTX
強化学習 DQNからPPOまで
by
harmonylab
PDF
ユークリッド最小全域木
by
理玖 川崎
PPTX
強化学習アルゴリズムPPOの解説と実験
by
克海 納谷
PPTX
2SAT(充足可能性問題)の解き方
by
Tsuneo Yoshioka
PDF
AtCoder Beginner Contest 007 解説
by
AtCoder Inc.
プログラミングコンテストでのデータ構造 2 ~平衡二分探索木編~
by
Takuya Akiba
色々なダイクストラ高速化
by
yosupo
グラフネットワーク〜フロー&カット〜
by
HCPC: 北海道大学競技プログラミングサークル
プログラミングコンテストでの乱択アルゴリズム
by
Takuya Akiba
直交領域探索
by
okuraofvegetable
明日使えないすごいビット演算
by
京大 マイコンクラブ
ウェーブレット木の世界
by
Preferred Networks
様々な全域木問題
by
tmaehara
Convex Hull Trick
by
HCPC: 北海道大学競技プログラミングサークル
二部グラフの最小点被覆と最大安定集合と最小辺被覆の求め方
by
Kensuke Otsuki
勉強か?趣味か?人生か?―プログラミングコンテストとは
by
Takuya Akiba
AtCoder Beginner Contest 034 解説
by
AtCoder Inc.
深さ優先探索による塗りつぶし
by
AtCoder Inc.
モデル高速化百選
by
Yusuke Uchida
競技プログラミングにおけるコードの書き方とその利便性
by
Hibiki Yamashiro
強化学習 DQNからPPOまで
by
harmonylab
ユークリッド最小全域木
by
理玖 川崎
強化学習アルゴリズムPPOの解説と実験
by
克海 納谷
2SAT(充足可能性問題)の解き方
by
Tsuneo Yoshioka
AtCoder Beginner Contest 007 解説
by
AtCoder Inc.
Viewers also liked
PDF
最小カットを使って「燃やす埋める問題」を解く
by
shindannin
PDF
実践・最強最速のアルゴリズム勉強会 第五回講義資料(ワークスアプリケーションズ & AtCoder)
by
AtCoder Inc.
PDF
【Unity道場スペシャル 2017札幌】最適化をする前に覚えておきたい技術 -札幌編-
by
Unity Technologies Japan K.K.
PDF
AtCoder Regular Contest 049 解説
by
AtCoder Inc.
PPTX
AtCoderに毎回参加したくなる仕組み
by
AtCoder Inc.
PDF
素集合データ構造
by
京大 マイコンクラブ
PDF
An Internal of LINQ to Objects
by
Yoshifumi Kawai
PDF
幾何コンテスト2013
by
Naoto Mizuno
PDF
【Unite 2017 Tokyo】パフォーマンス向上のためのスクリプトのベストプラクティス
by
Unity Technologies Japan K.K.
PPTX
TCO2017R1
by
AtCoder Inc.
最小カットを使って「燃やす埋める問題」を解く
by
shindannin
実践・最強最速のアルゴリズム勉強会 第五回講義資料(ワークスアプリケーションズ & AtCoder)
by
AtCoder Inc.
【Unity道場スペシャル 2017札幌】最適化をする前に覚えておきたい技術 -札幌編-
by
Unity Technologies Japan K.K.
AtCoder Regular Contest 049 解説
by
AtCoder Inc.
AtCoderに毎回参加したくなる仕組み
by
AtCoder Inc.
素集合データ構造
by
京大 マイコンクラブ
An Internal of LINQ to Objects
by
Yoshifumi Kawai
幾何コンテスト2013
by
Naoto Mizuno
【Unite 2017 Tokyo】パフォーマンス向上のためのスクリプトのベストプラクティス
by
Unity Technologies Japan K.K.
TCO2017R1
by
AtCoder Inc.
Similar to Union find(素集合データ構造)
PPTX
充足可能性問題のいろいろ
by
Hiroshi Yamashita
PDF
実践・最強最速のアルゴリズム勉強会 第二回講義資料(ワークスアプリケーションズ & AtCoder)
by
AtCoder Inc.
PDF
Nazoki
by
Ken Ogura
PDF
蟻本輪講 データ構造
by
HCPC: 北海道大学競技プログラミングサークル
PPTX
サンプルで学ぶAlloy
by
NSaitoNmiri
KEY
形式手法とalloyの紹介
by
Daisuke Tanaka
KEY
Algebraic DP: 動的計画法を書きやすく
by
Hiromi Ishii
PDF
PFDS 5.5 Pairing heap
by
昌平 村山
PDF
130604 fpgax kibayos
by
Mikio Yoshida
PPTX
yyoshida thesis
by
Yuichi Yoshida
PDF
Ibisml2011 06-20
by
Yasuo Tabei
PDF
データを工夫して記録するデータ構造
by
Katsutoshi Nagaoka
PPTX
IJPC-2 D問題解説
by
yutaka1999
PDF
130323 slide all
by
ikea0064
PPTX
Arc 010 d
by
Yuma Inoue
PDF
Sharp2sat
by
oupc
PPTX
私、木になります
by
gotoloop
PDF
kibayos beaker-070829
by
Mikio Yoshida
PDF
CODE THANKS FESTIVAL 2014 A日程 解説
by
AtCoder Inc.
PDF
Image Slide ( Animal Companion in Maze )
by
tadamasa yamaguchi
充足可能性問題のいろいろ
by
Hiroshi Yamashita
実践・最強最速のアルゴリズム勉強会 第二回講義資料(ワークスアプリケーションズ & AtCoder)
by
AtCoder Inc.
Nazoki
by
Ken Ogura
蟻本輪講 データ構造
by
HCPC: 北海道大学競技プログラミングサークル
サンプルで学ぶAlloy
by
NSaitoNmiri
形式手法とalloyの紹介
by
Daisuke Tanaka
Algebraic DP: 動的計画法を書きやすく
by
Hiromi Ishii
PFDS 5.5 Pairing heap
by
昌平 村山
130604 fpgax kibayos
by
Mikio Yoshida
yyoshida thesis
by
Yuichi Yoshida
Ibisml2011 06-20
by
Yasuo Tabei
データを工夫して記録するデータ構造
by
Katsutoshi Nagaoka
IJPC-2 D問題解説
by
yutaka1999
130323 slide all
by
ikea0064
Arc 010 d
by
Yuma Inoue
Sharp2sat
by
oupc
私、木になります
by
gotoloop
kibayos beaker-070829
by
Mikio Yoshida
CODE THANKS FESTIVAL 2014 A日程 解説
by
AtCoder Inc.
Image Slide ( Animal Companion in Maze )
by
tadamasa yamaguchi
More from AtCoder Inc.
PDF
AtCoder Beginner Contest 035 解説
by
AtCoder Inc.
PDF
AtCoder Regular Contest 045 解説
by
AtCoder Inc.
PDF
Square869120 contest #2
by
AtCoder Inc.
PDF
CODE FESTIVAL 2015 予選A 解説
by
AtCoder Inc.
PDF
arc047
by
AtCoder Inc.
PDF
AtCoder Beginner Contest 029 解説
by
AtCoder Inc.
PDF
AtCoder Regular Contest 046
by
AtCoder Inc.
PDF
abc031
by
AtCoder Inc.
PDF
AtCoder Beginner Contest 033 解説
by
AtCoder Inc.
PDF
AtCoder Beginner Contest 030 解説
by
AtCoder Inc.
PDF
Chokudai Contest 001
by
AtCoder Inc.
PDF
AtCoder Regular Contest 048
by
AtCoder Inc.
PDF
CODE FESTIVAL 2015 解説
by
AtCoder Inc.
PDF
AtCoder Regular Contest 044 解説
by
AtCoder Inc.
PDF
CODE FESTIVAL 2015 予選B 解説
by
AtCoder Inc.
PDF
abc032
by
AtCoder Inc.
PDF
CODE FESTIVAL 2015 沖縄ツアー 解説
by
AtCoder Inc.
PDF
DDPC 2016 予選 解説
by
AtCoder Inc.
PDF
Disco Presents ディスカバリーチャンネルプログラミングコンテスト2016 本選 解説
by
AtCoder Inc.
PDF
MUJINプログラミングチャレンジ2016 解説
by
AtCoder Inc.
AtCoder Beginner Contest 035 解説
by
AtCoder Inc.
AtCoder Regular Contest 045 解説
by
AtCoder Inc.
Square869120 contest #2
by
AtCoder Inc.
CODE FESTIVAL 2015 予選A 解説
by
AtCoder Inc.
arc047
by
AtCoder Inc.
AtCoder Beginner Contest 029 解説
by
AtCoder Inc.
AtCoder Regular Contest 046
by
AtCoder Inc.
abc031
by
AtCoder Inc.
AtCoder Beginner Contest 033 解説
by
AtCoder Inc.
AtCoder Beginner Contest 030 解説
by
AtCoder Inc.
Chokudai Contest 001
by
AtCoder Inc.
AtCoder Regular Contest 048
by
AtCoder Inc.
CODE FESTIVAL 2015 解説
by
AtCoder Inc.
AtCoder Regular Contest 044 解説
by
AtCoder Inc.
CODE FESTIVAL 2015 予選B 解説
by
AtCoder Inc.
abc032
by
AtCoder Inc.
CODE FESTIVAL 2015 沖縄ツアー 解説
by
AtCoder Inc.
DDPC 2016 予選 解説
by
AtCoder Inc.
Disco Presents ディスカバリーチャンネルプログラミングコンテスト2016 本選 解説
by
AtCoder Inc.
MUJINプログラミングチャレンジ2016 解説
by
AtCoder Inc.
Recently uploaded
PPTX
socialization in fundamentals of sociology.pptx
by
mpevk202
PDF
ПЛАН_профілактика правопорушень02.09.25.pdf
by
AleksSaf
PDF
ПОЛОЖЕННЯ_протидія насильству_підписане.pdf
by
AleksSaf
PDF
Seminar midterm presentation by Chihana Usui
by
aa123032
PDF
ПЛАН_навчально_профілактичні_заходи_запобігання_негативним_проявам.pdf
by
AleksSaf
PDF
ГРАФІК ГУРТКОВОЇ РОБОТИ 2025 kg72 grafik
by
AleksSaf
PDF
Bases especialista admen rrhh minedu.pdf
by
hpajsib
socialization in fundamentals of sociology.pptx
by
mpevk202
ПЛАН_профілактика правопорушень02.09.25.pdf
by
AleksSaf
ПОЛОЖЕННЯ_протидія насильству_підписане.pdf
by
AleksSaf
Seminar midterm presentation by Chihana Usui
by
aa123032
ПЛАН_навчально_профілактичні_заходи_запобігання_негативним_проявам.pdf
by
AleksSaf
ГРАФІК ГУРТКОВОЇ РОБОТИ 2025 kg72 grafik
by
AleksSaf
Bases especialista admen rrhh minedu.pdf
by
hpajsib
Union find(素集合データ構造)
1.
Union-Find (素集合データ構造)
2.
• グループ分けを管理する • はじめ,𝑛
個の物は全て別々のグループ • 次の 2 種類のクエリに対応する 1. 「まとめる」 2. 「判定」 Union-Find 木の機能 1 2 3 4 5
3.
クエリ 1:まとめる • 2
つのグループを 1 つにまとめる 1 2 1 2 1 3 2 4 6 1 2 3 4 6
4.
クエリ 2:判定 • 2
つの要素が同じグループに属しているかを判 定する 1 3 2 4 6 5 1 と 3 → true 1 と 2 → false
5.
素朴な実現法 (1/2) • 配列に,同じグループなら同じ数字を入れてお く 1
3 2 4 6 5 1 2 3 4 5 6 1 2 1 2 5 2
6.
素朴な実現法 (2/2) • この方針の問題点 –
グループをまとめる際に,𝑂(𝑛) 時間かかってしまう – 実際には,この方針でも少しの工夫でならし 𝑂(log 𝑛) 時間にできます http://topcoder.g.hatena.ne.jp/iwiwi/20131226/1388062106 • Union-Find 木は,もっと効率的に行う
7.
Union-Find 木 • グループを,1
つの木で表現する – したがって,全体では森 1 3 2 4 6 5 1 3 2 4 6 5
8.
クエリ1:「まとめる」 • 片方の木の根からもう片方の根に辺を張ればよ い 1 2 1 2 1 3 2 4
6 1 3 2 4 6 1 と 2 をまとめる 2 から 1 に辺を張る
9.
クエリ2:「判定」 • 2 つの要素を上に辿って,根が同じかどうかを 見ればよい 1 3 2 4
6 5 2 と 6 → 根は共に 2 → true 1 と 4 → 根は 1 と 2 → false
10.
Union-Find 木の効率 • 正当性:このやり方で,グループの判定はうま くできる •
効率:最悪の場合,この方法でも ツリーが縦長になると処理が遅く なってしまう → 効率化のテクニックを導入
11.
効率化工夫 1:経路圧縮 • 上向きに辿って再帰的に根を調べる際に,調べ たら辺を根に直接つなぎ直す •
4 の根を調べると,2, 3, 4 の根が 1 と分かる 1 2 3 4 1 2 3 4
12.
効率化工夫 2:ランク • 木の高さを持っておき,低い方を高い方に繋げ るようにする •
ただし,経路圧縮と組み合わせた際,経路圧縮による高 さの減少は無視する (つまり,ランクは経路圧縮しなかった場合の高さに相当する) 1 2 3 4 5 1 2 3 4 5 ランク 3 ランク 2 ランク 3
13.
Union-Find 木の計算量 • 2
つの工夫の両方をして 𝑂(𝛼(𝑛)) – 𝛼(𝑛) はアッカーマン関数 𝐴(𝑛, 𝑛) の逆関数 – 相当小さい(log より小さい!) • 片方だけでも,だいたい 𝑂(log 𝑛) – 経路圧縮のみが実装が楽でよい • これらはならし計算量
14.
Union-Find 木の実装(ランク無し) • 経路圧縮のみ(ランクは使わない) •
par[i] = i ならば根 – はじめは全部の頂点が根 int par[MAX_N]; // 親の番号 // n 要素で初期化 void init(int n) { for (int i = 0; i < n; i++) par[i] = i; }
15.
// 木の根を求める int root(int
x) { if (par[x] == x) { // 根 return x; } else { return par[x] = root(par[x]); // 経路圧縮 } } // x と y が同じ集合に属するか否か bool same(int x, int y) { return root(x) == root(y); } Union-Find 木の実装(ランク無し)
16.
// x と
y の属する集合を併合 void unite(int x, int y) { x = root(x); y = root(y); if (x == y) return; par[x] = y; } Union-Find 木の実装(ランク無し)
17.
Union-Find 木の実装(ランク有り) int par[MAX_N],
rank[MAX_N]; void init(int n) { for (int i = 0; i < n; i++) { par[i] = i; rank[i] = 0; } } int root(int x) { return par[x] == x ? x : par[x] = root(par[x]); } bool same(int x, int y) { return root(x) == root(y); } void unite(int x, int y) { x = root(x); y = root(y); if (x == y) return; if (rank[x] < rank[y]) { par[x] = y; } else { par[y] = x; if (rank[x] == rank[y]) rank[x]++; } }
18.
補足 • Union-Find 木はグループをまとめることはでき ても,分割することはできない 重要な制約 •
Union-Find 木を改造して機能を付加することが 必要になるような問題もあります
Download