2015 ec-final Problem F. Hungry Game of Ants 動規(guī)計數(shù)

題意

有n只螞蟻分別在1到n的位置(左右還有位置0和位置n + 1)里烦,他們的重量分別是1到n废菱,其實n只螞蟻分別隨機選取左右中的一個方向同時開始行走(走到頭就轉(zhuǎn)向),兩只螞蟻相遇就打架,較重的獲勝,較輕的被吃掉崭参,并且重量變成兩者之和,問最后第k只螞蟻活下來的方案數(shù)(總共2 ^ n種情況)

樣例

3
2 1      Case #1: 0
3 2      Case #2: 4
4 2      Case #3: 4
樣例2中的方案:左左左款咖,左左右何暮,右左左奄喂,右左右
2 ≤ N ≤ 10 ^ 6
1 ≤ K ≤ N

思路

(1)第k只螞蟻必然是先向左(k != n的情況下),吃掉左邊所有的螞蟻海洼,然后向右跨新。我們先計算出吃掉k左邊所有螞蟻的方案數(shù),可以分為兩步坏逢,首先是直接吃掉一段靠近k的且向右走的螞蟻域帐,然后靠左的一段形成一致大螞蟻,然后被靠右的吃掉是整。比如k = 6俯树,5向右走,6吃掉5贰盗;4向左走,將1阳欲, 2舵盈, 3, 4形成一只重量是10的大螞蟻球化,然后被6和5形成的11大螞蟻吃掉秽晚。我們可以枚舉靠右的那一段。

(2)在1到k都被吃掉后筒愚,可以動規(guī)解決后面的情況赴蝇。dp[i]表示前i只螞蟻已經(jīng)合并的方案數(shù),可以枚舉這只大螞蟻最后吃掉的那一段巢掺,那么:
dp[i] = sigma{dp[j] | j < i && 1到j形成的大螞蟻可以吃掉j + 1到i形成的大螞蟻}

代碼

#define rep(i, n) for (int i = 0; i < (n); i++)
#define FOR(i, n, m) for (int i = (n); i <= (m); i++)

const int N = 1000000, MOD = 1000000007;

int T, n, m;
LL pre[N + 5], c[N + 5];
LL dp[N + 5], sd[N + 5];

void init() {
    pre[0] = 0, c[0] = 1;
    FOR (i, 1, N) {
        pre[i] = pre[i - 1] + i;
        c[i] = c[i - 1] * 2 % MOD;
    }
}

int solve() {
    if (n == 1) return 2;
    if (m == 1) return 0;
    LL sum = 0, tmp = 1, p = m, now = pre[p];
    FORD (i, m, 2) {
        sum += i;
        if (sum <= pre[m] - sum) continue;
        tmp = (tmp + c[i - 2]) % MOD;
    }
    if (m == n) return tmp * 2 % MOD;
    memset(dp, 0, sizeof(dp));
    memset(sd, 0, sizeof(sd));
    dp[m] = tmp, sd[m] = tmp;
    FOR (i, m + 1, n) {
        while (now < pre[i] - now) now += (++p);
        dp[i] = (sd[i - 1] - sd[p - 1]) * (i == n ? 2 : 1);
        dp[i] = (dp[i] + 2 * MOD) % MOD;
        sd[i] = (sd[i - 1] + dp[i]) % MOD;
        //sc3(i, p, dp[i]);
    }
    return (int) dp[n];
}

int main() {
    file_r("in.txt");
    file_w("out.txt");
    int cas = 0;
    scanf("%d", &T);
    //T = 55;
    init();
    //file_w("out.txt");

    while (T--) {
        scanf("%d %d", &n, &m);
        //FOR (i, 1, 10) FOR (j, 1, i) {
        //    n = i, m = j;
            printf("Case #%d: %d\n", ++cas, solve());
        //}
    }
    return 0;
}

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末句伶,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子陆淀,更是在濱河造成了極大的恐慌考余,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件轧苫,死亡現(xiàn)場離奇詭異楚堤,居然都是意外死亡,警方通過查閱死者的電腦和手機含懊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進店門身冬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人岔乔,你說我怎么就攤上這事酥筝。” “怎么了重罪?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵樱哼,是天一觀的道長哀九。 經(jīng)常有香客問我,道長搅幅,這世上最難降的妖魔是什么阅束? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮茄唐,結(jié)果婚禮上息裸,老公的妹妹穿的比我還像新娘。我一直安慰自己沪编,他們只是感情好呼盆,可當我...
    茶點故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蚁廓,像睡著了一般访圃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上相嵌,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天腿时,我揣著相機與錄音,去河邊找鬼饭宾。 笑死批糟,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的看铆。 我是一名探鬼主播徽鼎,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼弹惦!你這毒婦竟也來了否淤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤棠隐,失蹤者是張志新(化名)和其女友劉穎叹括,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體宵荒,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡汁雷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了报咳。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片侠讯。...
    茶點故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖暑刃,靈堂內(nèi)的尸體忽然破棺而出厢漩,到底是詐尸還是另有隱情,我是刑警寧澤岩臣,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布溜嗜,位于F島的核電站宵膨,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏炸宵。R本人自食惡果不足惜辟躏,卻給世界環(huán)境...
    茶點故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望土全。 院中可真熱鬧捎琐,春花似錦、人聲如沸裹匙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至腻异,卻和暖如春话浇,著一層夾襖步出監(jiān)牢的瞬間煎楣,已是汗流浹背筷转。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工蔚万, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人徽曲。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像麸塞,于是被迫代替她去往敵國和親秃臣。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,969評論 2 355

推薦閱讀更多精彩內(nèi)容