250pt MagicalGirlLevelOneDivOne
某神在(0,0)處, 需要走到(x,y)處(0<x,y<=10^9), 他只能按類似馬跳的方式走, 即, 給出一個n, 他可以從(a,b)走到(a-1,b-n) (a+1,b-n) (a-1,b+n) (a+1,b+n) (a-n,b-1) (a+n,b-1) (a-n,b+1) (a+n, b+1) 中的一個.現在給出50個不同的n[1..50], 他可以以任意的n[i]方式走, 每種方式的使用次數不限. 問能否走到目的地(x,y).
很明顯, 此神可以沿任意方向2步2步的走, 即先走個(+1,-n), 再走個(+1,+n). 所以能否到終點, 只與奇偶性有關.
經過一陣分類討論可知:
1) 如果x+y=0(mod 2), 則YES.
2) 如果x+y=1(mod 2), 且n[i]中有偶數, 則YES.
3) 否則NO.
[雜]
600pt MagicalGirlLevelTwoDivOne
給一個H*W(1<=H,W<=50)的矩陣A, 每一位上已經有一個1~9的數字, 或者是個'.', 在'.'處可以填上任意1~9的數字. 再給出n和m(1<=n<=min{10,H}, 1<=m<=min{10,W}). 問一共有多少種填'?'的方法, 使得整個矩陣滿足:
對任意的r和c, 以(r,c)開始的水平方向上連續m個數之和是奇數;
對任意的r和c, 以(r,c)開始的垂直方向上連續n個數之和是奇數.
首先要注意到一個性質: 對任意r和c有 A[r,c]與A[r+n,c]的奇偶性相同. 很顯然, 因為要滿足A[r,c]+A[r+1,c]+...+A[r+n-1,c]與A[r+1,c]+...+A[r+n-1,c]+A[r+n,c]的奇偶性相同, 都是奇數. 列上同樣有A[r,c]與A[r,c+m]奇偶性相同.
因此在一行上, 只用記錄n位的奇偶狀態, 列上同理. 這樣,所有的(r+pn,c+qm)都能合并成同一個點, 且只有兩種狀態: 奇和偶. 合并后該點為奇(或偶)的方法數, 等于組成它的所有點方法數之積. 最后整個矩陣合并壓縮成一個n*m的矩陣, 就可以用狀態DP來搞, 求每行每列之和都為奇的方法數. dp[n][1<<m], 前n行, 每一列和的奇偶性對應bit為0或1. O(1<<m)的轉移復雜度, 轉移時要注意該行狀態1有奇數個.
覺得是道很好的題, 狀態設計很巧妙...
[狀態DP 狀態壓縮設計]
900pt MagicalGirlLevelThreeDivOne
某神給出K(K<=50)個01串, 每個串的長度不超過50. 用這些串組成新的串放到數組A[]里. 如果i<K, 則A[i]為給出的第i個串. 否則A[i] = A[i-1] + A[i-K-1] + A[i-2*K-1] + ... + A[i-p*K-1], 其中p是使i-p*K-1>=0的最大整數. 現在此神給出n, lo, hi, 要你求A[n]的子串A[n][lo...hi]中有多少個連續的1. 0<=n<=10^15, 0<=hi<= min{A[n]的長度, 10^15}, 0<=lo<=hi. 所有計數以0開始.
首先隨便打個表或者手推一下化簡A[i]的遞推式, 可以發現當i>=2*K時, A[i] = A[i-1] + (A[i-K-1] + ... A[i-p*K-1]) = A[i-1] + A[i-K], 而K<=50. 所以A[i]的長度關于i是指數增長的, 50log(10^15)可能夠用(嚴格證明不太會, 求指導#.#). 因此其實n<=10^15范圍是坑爹的, hi不會超過A[10^4]的長度. 而這些串的前綴都是一樣的, 所以A[n][lo..hi]其實與A[10^4][lo..hi]相同.
這樣便可直接利用A[i] = A[i-1] + A[i-K]的關系分治. 和用線段樹求最長連續1串的思想差不多: 每個結點的狀態變量是(id,lo,hi), 存放A[id][lo..hi]的最優解. 除了存放當前段的最大長度max外, 為了能合并子區間, 還要記錄當前區間從左端開始連續1的個數sl, 和從右端開始連續1的個數sr. 剩下的工作與線段樹無異, 假設要求(id, lo, hi)的(max, sl, sr):
對于A[id], 它的左兒子就是A[id-1], 右兒子是A[id-K].
1)如果id<2*K, 直接暴力.
2)如果lo>=len[id-1](類似于線段樹中的查詢區間完全落在右兒子), 則遞歸查詢(id-K, lo-len[id-1], hi-len[id-1]).
3)如果hi<len[id-1], 則遞歸查詢(id-1, lo, hi).
4)否則兩個兒子都要查詢, 并根據返回的結果求當前區間的結果.
分治思想很強大, 用map寫的"線段樹"很YD, 偶依然蒻爆了.
[分治 復雜度分析]
| |||||||||
日 | 一 | 二 | 三 | 四 | 五 | 六 | |||
---|---|---|---|---|---|---|---|---|---|
31 | 1 | 2 | 3 | 4 | 5 | 6 | |||
7 | 8 | 9 | 10 | 11 | 12 | 13 | |||
14 | 15 | 16 | 17 | 18 | 19 | 20 | |||
21 | 22 | 23 | 24 | 25 | 26 | 27 | |||
28 | 29 | 30 | 31 | 1 | 2 | 3 | |||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
"Do not spend all your time on training or studying - this way you will probably become
very exhausted and unwilling to compete more.
Whatever you do - have fun. Once you find programming is no fun anymore
– drop it. Play soccer, find a girlfriend, study something not related
to programming, just live a life - programming contests are only
programming contests, and nothing more. Don't let them become your life
- for your life is much more interesting and colorful."
-- Petr
留言簿(3)
隨筆分類(59)
隨筆檔案(43)
- 2013年9月 (1)
- 2011年8月 (3)
- 2011年7月 (3)
- 2011年6月 (1)
- 2011年5月 (1)
- 2010年5月 (3)
- 2010年4月 (1)
- 2009年12月 (1)
- 2009年10月 (1)
- 2009年9月 (1)
- 2009年7月 (6)
- 2009年6月 (7)
- 2009年5月 (3)
- 2009年4月 (3)
- 2009年3月 (4)
- 2009年2月 (2)
- 2008年2月 (2)
cows
搜索
最新評論

- 1.?re: srm 514 div1 250 600 900
- 請高手幫忙啊,我給你留言了,SRM 144 DIV1 的1100分的題,請幫忙分析一下啊,我的郵箱:ervin_yue@163.com
- --ervin_yue
- 2.?re: 人民搜索筆試.坑爹題...
-
能要下您的q號嗎,我最近也要去筆試人民搜索,
能多了解下嗎,
我的q 3323 08723
謝謝
- --栗
- 3.?re: pku 2486 Apple Tree 樹形DP+背包DP
- 這樣做復雜度應該是n*n*k*k
- --kimiyoung
- 4.?re: Two Professors (CERC 2008) 解題報告
- Up!
- --zaakdov
- 5.?re: 字符串匹配 后綴數組 trie圖(更新)
-
@小狗
Thanks~~ 手誤了 - --<A href="mailto:wolf5x1016@gmail.com"