Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
joi2012-sp-day2-broadcasting
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Masaki Hara
March 21, 2012
Programming
230
1
Share
joi2012-sp-day2-broadcasting
第11回 日本情報オリンピック 春合宿 競技2日目 「テレビ放送(Broadcasting)」 解説スライド
Masaki Hara
March 21, 2012
More Decks by Masaki Hara
See All by Masaki Hara
文字コードの話
qnighy
47
19k
バックエンドのためのアプリ内課金入門 (サブスク編)
qnighy
9
2.5k
Dockerfileの考え方
qnighy
50
19k
Arm移行タイムアタック
qnighy
1
730
Quine, Polyglot, 良いコード
qnighy
5
890
Prolog入門
qnighy
5
2.8k
Rubyのobject_id
qnighy
8
1.8k
Getting along with YAML comments with Psych
qnighy
2
3.1k
状態設計から「なんとなく」を無くそう
qnighy
90
30k
Other Decks in Programming
See All in Programming
さぁV100、メモリをお食べ・・・
nilpe
0
130
技術記事、AIに書かせるか、自分で書くか? 〜それでも私が自分の手で書く理由〜 / #QiitaConference
jnchito
2
1.3k
JJUG CCC 2026 Spring: JSpecify で実現する Kotlin フレンドリーな Java API 設計
ternbusty
1
140
タクシーアプリ『GO』の バックエンド開発のおける AI利活用と若者のすべて
pyama86
3
1.9k
Spring Security 実践 ─ GraphQL APIで実務に役立つ 認証・認可 を学ぶ
wagyu
0
110
GitHub Copilot CLIのいいところ
htkym
2
1.3k
Spec Driven Development | AI Summit Lisbon
danielsogl
PRO
0
150
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
350
ADKを使って簡単にAIエージェントを作ってみよう
k1mu21
0
220
SPMマルチモジュールで テストカバレッジを取得する技法
yosshi4486
0
140
Spec-Driven Development with AI-Agents: From High-Level Requirements to Working Software
antonarhipov
2
450
キャリア迷子上等 ─ "ない道"は自分で作ればいい
16bitidol
2
430
Featured
See All Featured
Code Reviewing Like a Champion
maltzj
528
40k
Making the Leap to Tech Lead
cromwellryan
135
9.9k
The AI Search Optimization Roadmap by Aleyda Solis
aleyda
1
5.9k
Claude Code のすすめ
schroneko
67
230k
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
160
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
300
How to train your dragon (web standard)
notwaldorf
97
6.7k
Impact Scores and Hybrid Strategies: The future of link building
tamaranovitovic
0
300
VelocityConf: Rendering Performance Case Studies
addyosmani
333
25k
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
2
1.5k
A designer walks into a library…
pauljervisheath
211
24k
Efficient Content Optimization with Google Search Console & Apps Script
katarinadahlin
PRO
1
590
Transcript
Masaki Hara @qnighy 2歳のとき強く頭を打ち、算数に目覚める。 9歳のとき強く頭を打ち、プログラミングに目覚める。 10歳のとき強く頭を打ち、Javaに目覚める。 14歳のとき強く頭を打ち、アニメに目覚める。 15歳のとき強く頭を打ち、アルゴリズムに目覚める。 17歳のとき強く頭を打ち、形式的定理証明に目覚める https://twitter.com/#!/qnighy/status/25315686027
問題 平面上にN個の点がある K個の円を配置(場所・大きさは任意)し、それらの点をカ バーする それぞれの円について、半径の二乗に比例するコストが かかる
コストの合計値を小さくしたい 出力のみ提出
問題 平面上にN個の点がある K個の円を配置(場所・大きさは任意)し、それらの点をカ バーする それぞれの円について、半径の二乗に比例するコストが かかる
コストの合計値を小さくしたい 出力のみ提出
出力のみ問題! 一般的なアドヴァイスから
出力のみ問題! (1) 入力を見ながらコーディングできる 入力データの特徴は最大限活用しよう そのためにビジュアライザが欲しい時もある
出力のみ問題! (2) プログラムを提出する必要がない いくつプログラムを使ってもよい 手作業をしてもよい 場合によっては有用(e.g.
IOI2010 Maze) ただし、Wrong Answerに注意
出力のみ問題! (3) プログラムを提出する必要がない 1秒以内に実行する必要はない 長い時間かけて良い答えを得る C/C++で書く必要もない
Ubuntuなら、bash, Perl, Pythonは確実に入っています ブラウザでJavaScriptを動かすこともできます ただし、コンテストの禁止事項には注意
出力のみ問題! (4) 何回でも挑戦できます 出力のみ問題では、手動でのパラメーター調整が重要にな ります。 時間をかけるほど良い解が出るプログラムはgood
パラメーター調整が簡単にできるようにするとgood
出力のみ問題! (5) ※5時間コンテストです!!! 出力のみ問題にこだわりすぎないように 無制限に時間を消費するので、最後にするのが無難? 複雑な戦略(焼きなましやGA)は、5時間コンテストではあま
り力を発揮しないかもしれません パラメーター調整が難しいし。 山登り法や「焼きっぱなし」がおすすめです
出力のみ問題! 入力データの特徴を活用する いくつプログラムを作ってもよい 好きなだけ実行してよい
閑話休題
問題 平面上にN個の点がある K個の円を配置(場所・大きさは任意)し、それらの点をカ バーする それぞれの円について、半径の二乗に比例するコストが かかる
コストの合計値を小さくしたい
入力の性質 ビジュアライザを書く JavaScript+Canvasで絵を描けます
入力の性質 ビジュアライザを書く
入力の性質 01.txt 02.txt
入力の性質 03.txt 04.txt
入力の性質 05.txt
入力の性質: 考察 入力によって性質が違う 均等なもの (01, 05) 若干ばらつきのあるもの(02,
03) 狙ってるとしか思えないもの(04) アルゴリズムによって得手不得手がありそう
考察 考察: カバーしたい点集合に対して、最小包含円を決め ることができる →以下の2つの問題に分かれる K個の点集合を作る
それぞれの点集合について、最小包含円を求める
最小包含円 与えられた点を全て含む円で、最も半径が小さいもの O(n^3) 平均O(n) その他 -
貪欲法やエセ最小包含円
最小包含円 - O(n^3) ≤ 2 のときは自明 = 3
のとき 鈍角三角形の場合…一番長い辺が直径 鋭角三角形の場合…外接円を考える ≥ 3 のとき 全ての三角形を考えて、その最小包含円のうち最も大きい ものを選べばよい
最小包含円 – 平均O(n) min_disk(, ): 点集合とを含む最小包含円を求める。 ただしは周上にあることが保証されている。 が空なら、
の外接円が答え から点をひとつ選び、とする を除いた最小包含円min_disk( − , )をとおく。 ∈ なら、が答え ∉ なら、 は最小包含円の周上にある → min_disk( − , + {})が答え
最小包含円 – 平均O(n) 点の順番がランダムになっているとする 最小包含円の周上に点は3個程度しかない → min_disk(
− , + {}) が呼び出される確率は (3 − #)/程度 したがって、平均で()
最小包含円 – その他の方法 中心を決めると、必要な半径は で求まる 貪欲法 円の中心を、必要な半径が小さくなる方向に進めていく
適当な値で代用する 円の中心 = 全ての点をカバーする矩形の中心 などとおく それなりに良く近似できるし、簡単に書ける
K個の点集合を決める 乱択で近傍探索 クラスタ解析 その他の方法
K個の点集合 – 近傍探索 とりあえず適当に点集合をおく(乱数とかで) 近傍は以下のように選ぶ 適当な点を選び、適当な集合に移動させる
スコアに応じて、その近傍に移動する 均等なデータのほうが強い
K個の点集合 – クラスタ解析 データ群を類似関係にあるグループに分類する方法 ここでは「K平均法」を使う
K個の点集合 – クラスタ解析 データ群を類似関係にあるグループに分類する方法 ここでは「K平均法」を使う
K個の点集合 – クラスタ解析 データ群を類似関係にあるグループに分類する方法 ここでは「K平均法」を使う 平均
K個の点集合 – クラスタ解析 データ群を類似関係にあるグループに分類する方法 ここでは「K平均法」を使う 平均
K個の点集合 – クラスタ解析 データ群を類似関係にあるグループに分類する方法 ここでは「K平均法」を使う 平均
K個の点集合 – クラスタ解析 データ群を類似関係にあるグループに分類する方法 ここでは「K平均法」を使う 平均
K個の点集合 – クラスタ解析 データ群を類似関係にあるグループに分類する方法 ここでは「K平均法」を使う まばらなデータに強い
K個の点集合 – その他の方法 Kruskal法と同様に、N個から併合を繰り返してK個にす る
その他の方法の紹介 中心決め打ち 貪欲法などを使って半径を決める
それでは
生徒の最良データの紹介
生徒の最良データの紹介 in01 JPN17 スコア 247498181034
生徒の最良データの紹介 in02 JPN18 スコア 246525708455
生徒の最良データの紹介 in03 JPN18 スコア 208558463568
生徒の最良データの紹介 in04 JPN18 スコア 176846776195
生徒の最良データの紹介 in05 JPN18 スコア 342198348502
参考: 得点分布 0 2 4 6 8 10 12 14
まとめ 出力のみ問題に特化した戦略を とにかくプログラムを回しまくるとか 5時間という短い時間内でできることを この時間内でできる戦略をしよう
01→適当な最小包含円+局所探索が良さそう 02-05→適当な最小包含円+クラスター分析が良さそう まだ改善の余地はあるとはいえ、5時間のコンテストでの 成績としては十分ではないでしょうか ただ、不正なデータで0点の人が多いのは勿体無いですね
ご清聴ありがとうございました 今日もよく寝て万全の体調で3日目に臨みましょう。
ご清聴ありがとうございました 今日もよく寝て万全の体調で3日目に臨みましょう。 (拍手!)