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
About累積和
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Catupper
August 22, 2013
How-to & DIY
0
1.6k
About累積和
ぷろ
しゅみ
るいせいき
わ
Catupper
August 22, 2013
Tweet
Share
More Decks by Catupper
See All by Catupper
ants' roots
catupper
1
2.6k
Trianguler
catupper
0
200
sort conference
catupper
2
120
計算量の話
catupper
0
1.1k
Graph is Fun
catupper
0
150
For You
catupper
1
160
Other Decks in How-to & DIY
See All in How-to & DIY
JAWS-UGとAWS - JAWS-UG彩の国埼玉設立のお祝い
awsjcpm
2
650
ポッドキャストをはじめよう ポッドキャストのやりかたと続けるコツ
takamichie
0
100
評価のギャップから紐解く、「評価軸」と「ソフトスキル」の重要性
blajir
2
150
2026年、書籍をちゃんと読むぞ👊 〜約3万円分の書籍を積読にしないためにやること〜
subroh0508
4
820
人を補助するAI ~AIとの壁打ちがきっかけになる~ #共創AIミートアップ
ishikiemo
2
560
JAWS-UG Community Upadate - JAWS-UG 熊本
awsjcpm
2
230
苦手の克服方法 / How to overcome weaknesses
toma_sm
0
360
雑にコミュニティを続けてもいいと思っている/Feel free to continue the community
camel_404
0
360
20250226_AI Code Agents祭り_MK_AIコーディングエージェントのコラボレーション開発
mk0721
PRO
0
150
「無理」を「コントロール」するスキル / Skills to Control "Muri"
hageyahhoo
6
3.9k
ライブ感を生む 巻き込み型スライドの作り方/Create your slide like a heavy metal concert
ikuodanaka
5
1.4k
個人制作コンテンツの多言語展開のノウハウを全公開! 〜世界に自分を発信しよう!〜
syotasasaki593876
0
160
Featured
See All Featured
Making the Leap to Tech Lead
cromwellryan
135
9.8k
Exploring anti-patterns in Rails
aemeredith
2
300
GitHub's CSS Performance
jonrohan
1032
470k
Code Review Best Practice
trishagee
74
20k
The Pragmatic Product Professional
lauravandoore
37
7.2k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
Imperfection Machines: The Place of Print at Facebook
scottboms
269
14k
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
10
1.1k
Navigating Team Friction
lara
192
16k
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.2k
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
230
Into the Great Unknown - MozCon
thekraken
40
2.3k
Transcript
なつやすみは突然に ひとなつの 競技プログラミング講座
ぱちぱちー 累積和
問題 • 長さ100,000の数列があります • いろいろな区間についてそこの合計を聞くので答えて – 100,000くらい聞く • 例: {1,
4, -1, 2, 5, 9, 10, -4, 5, 0} – 0〜7は? → 26 – 2〜4は? → 6 – 3〜9は? → 27 – …
愚直にやると? • 聞かれるたびにいちいち足して計算する – 最悪100,000 * 100,000で 10^10 – 遅い
そこまでの和をもつの • 累積和という概念をつかうとうまく行く – どこかからどこかまでの和のこと – 今回は一番左からそこまでの和 • 要素A[i]以左の要素の総和をS[i]とする •
A[l] + A[l + 1] + A[l + 2]... A[r] = S[r] – S[l – 1] • S[i]をすべて保存しておけば一回引き算するだけ – 計算は100,000回だけになる
これこそが 累積和
基本概念 • 連続した範囲の総和を持つこと • それを使うことで計算量を減らす • どう使うかはあなたが考える
たったの これだけ
演習問題 • AOJ0549 • 一直線上に宿屋がたくさんならんでいる • 旅人がその宿屋をある順番でめぐる • そのときの総移動距離を求めよ •
簡単なので考えてみて
Thinking Time • 3分で答えを考えてください • コードは実装しなくていいです
例題 • 最初は全部0の数列があります – サイズは10,000くらい • 連続した範囲に1足す操作をたくさんします – 10,000回くらい •
操作を全部し終わった後の数列の状態を教えて
わかりやすい図
ためされる頭脳 どうやってとくのか
逆転の発想 • さっきまでは、状態の累積和をとっていた • 今度はなにかの累積和が状態になるように考える • 元の状態を変えると累積和がどう変わるか考えてみる
+1してみる • 累積和する前のもの • 累積和をとった後
考察 • 累積和前の数列に1を足すとそれ以降全てが一様にたさ れる • 連続した範囲に一様に値を足すことの代わりになる – だけど余計なところまでたされてしまう • 余計なところは-1して帳尻をあわせる
-1でちょうじりあわせ • 累積和する前のもの • 累積和をとった後
これが港でゆうめいな いもす法
演習問題 • AOJ0231 • 重量制限がある崩れそうなヤバイ橋(ヤ橋)がある • その橋を何人かが渡ります – それぞれの渡り始め、渡り終わりの時刻 –
それぞれの体重 – が与えられる • 崩れるか崩れないか判断してください • 崩れるならいつ崩れるか教えてください
Thinking Time • 5分で答えを考えてください • コードは実装しなくていいです – ちょっとむずいです • わかった人は前に出て発表
– 先着1名
次元をこえて 2次元への応用
考え方はいっしょ • 累積和のつよみ – 1次元配列よりも2次元配列で本領を発揮する • 考え方は変わらないのでとりあえず例題
応用問題 • AOJ0560 • Jangle, Ocean, Iceの3種類の地形からなる地図が与えら れる – 2次元 1000
* 1000のマス目状 • ある長方形の範囲の中のJ,O,Iの数を教えてください – ということを100,000回します • うまく処理して
参考までに愚直解 • 聞かれるたびにいちいち答えるとクソおそいです – 1,000 * 1,000 * 100,000 =
10^11 – 数分かかる • 今回の問題はO(10^6)でとけます – がんばって考えよう
Thinking Time • 5分で答えを考えてください • コードは実装してもいいです – 時間かかるのでせんでもいいです • わかった人は前に出て発表
– 先着1名
答え • (0,0)を頂点にする全ての長方形の結果を持っておく – 1,000 * 1,000個 → O(10^6) –
A[i][j]を長方形(0,0) (i, j)の結果とする • 長方形(a,b) (c,d)の結果は – A[c, d] - A[a, d] – A[c, b] + A[a, b] – 一回の計算で出せる – O(100,000)
ちなみに 日本情報オリンピック 2010 本選第一問
宣伝 • 夏休みおわった直後くらいに申し込み始まります • 応募してちょ – 無料 – 参加は家から可能 –
予選を通れば東京にタダでいける – 代表に選ばれれば台湾にタダでいける – 来年はカザフスタン
その他応用問題たち • AOJ0509 – Sheets – メモリの工夫が必要 • AOJ0574 –
Nails – DPでもとけます • AOJ0580 – Fish – 座標圧縮が必要