【藍(lán)橋杯】第六屆-9-壘骰子

題目

賭圣atm晚年迷戀上了壘骰子,就是把骰子一個壘在另一個上邊,不能歪歪扭扭扛施,要壘成方柱體。
經(jīng)過長期觀察抢呆,atm 發(fā)現(xiàn)了穩(wěn)定骰子的奧秘:有些數(shù)字的面貼著會互相排斥煮嫌!
我們先來規(guī)范一下骰子:1 的對面是 4,2 的對面是 5抱虐,3 的對面是 6。
假設(shè)有 m 組互斥現(xiàn)象饥脑,每組中的那兩個數(shù)字的面緊貼在一起恳邀,骰子就不能穩(wěn)定的壘起來。 atm想計(jì)算一下有多少種不同的可能的壘骰子方式灶轰。
兩種壘骰子方式相同谣沸,當(dāng)且僅當(dāng)這兩種方式中對應(yīng)高度的骰子的對 應(yīng)數(shù)字的朝向都相同。
由于方案數(shù)可能過多笋颤,請輸出模 10^9 + 7 的結(jié)果乳附。

不要小看了 atm 的骰子數(shù)量哦~

「輸入格式」
第一行兩個整數(shù) n m
n表示骰子數(shù)目
接下來 m 行内地,每行兩個整數(shù) a b ,表示 a 和 b 不能緊貼在一起赋除。

「輸出格式」
一行一個數(shù)阱缓,表示答案模 10^9 + 7 的結(jié)果。

「樣例輸入」
2 1
1 2

「樣例輸出」
544

「數(shù)據(jù)范圍」
對于 30% 的數(shù)據(jù):n <= 5
對于 60% 的數(shù)據(jù):n <= 100
對于 100% 的數(shù)據(jù):0 < n <= 10^9, m <= 36

資源約定:
峰值內(nèi)存消耗(含虛擬機(jī)) < 256M
CPU消耗 < 2000ms

請嚴(yán)格按要求輸出举农,不要畫蛇添足地打印類似:“請您輸入...” 的多余內(nèi)容荆针。

所有代碼放在同一個源文件中,調(diào)試通過后颁糟,拷貝提交該源碼航背。
注意:不要使用package語句。不要使用jdk1.7及以上版本的特性棱貌。
注意:主類的名字必須是:Main玖媚,否則按無效代碼處理。

分析

經(jīng)過仔細(xì)的分析婚脱,會發(fā)現(xiàn)這是一道DP動態(tài)規(guī)劃問題今魔,可以先假設(shè)骰子的側(cè)面是固定的,然后通過舉例如下:
輸入:
2 1
1 2
此時(shí)的dp矩陣數(shù)組如下:

|      | 1    | 2    | 3    | 4    | 5    | 6    |
| ---- | ---- | ---- | ---- | ---- | ---- | ---- |
| 二層  | 5    | 5    | 6    | 6    | 6    | 6    |

輸入:
3 1
1 2
此時(shí)的dp矩陣數(shù)組如下:

|      | 1    | 2    | 3    | 4    | 5    | 6    | sum  |
| ---- | ---- | ---- | ---- | ---- | ---- | ---- | ---- |
| 二層  | 5    | 5    | 6    | 6    | 6    | 6    |34    |
| 三層  | 28   | 28   | 34   | 34   | 34   | 34   |192   |

具體變換過程如下:

|      | 1    | 2    | 3    | 4    | 5    | 6    | sum  |
| ---- | ---- | ---- | ---- | ---- | ---- | ---- | ---- |
| 1    | 5    | 5    | 6    | 6    | -    | 6    |28    |
| 2    | 5    | 5    | 6    | -    | 6    | 6    |28    |
| 3    | 5    | 5    | 6    | 6    | 6    | 6    |34    |
| 4    | 5    | 5    | 6    | 6    | 6    | 6    |34    |
| 5    | 5    | 5    | 6    | 6    | 6    | 6    |34    |
| 6    | 5    | 5    | 6    | 6    | 6    | 6    |34    |

從中分析可以發(fā)現(xiàn)當(dāng)n=3時(shí)起惕,每種情況都使用到了n=2時(shí)的數(shù)據(jù)涡贱,出現(xiàn)重疊子問題與最優(yōu)子結(jié)構(gòu),于是用DP來求解惹想。同時(shí)问词,為了節(jié)省空間,可以使用滾動DP來替代DP嘀粱。
最后激挪,由于側(cè)面方案數(shù)為4,那么在乘以4^n就可以了就可得到最終解锋叨。

代碼

import java.math.BigInteger;
import java.util.Scanner;

public class Nine {
    public static final int MOD = 1000000007;
    public static int init[] = { -1, 4, 5, 6, 1, 2, 3 }; // 骰子對面
    public static boolean conflict[][] = new boolean[7][7]; // 沖突

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int m = sc.nextInt();
        for (int i = 0; i < m; i++) {
            int a = sc.nextInt();
            int b = sc.nextInt();
            conflict[a][b] = conflict[b][a] = true;
        }

        // dp[i][j] 代表垄分,i個骰子且最頂面是j的情況種數(shù) 并且使用了滾動dp,否則會超空間
        BigInteger dp[][] = new BigInteger[2][7];
        int e = 0;
        for (int i = 1; i < 7; i++)
            dp[e][i] = BigInteger.ONE;

        for (int i = 2; i <= n; i++) {
            e = 1 - e;
            for (int j = 1; j < 7; j++) {
                dp[e][j] = BigInteger.ZERO;
                for (int k = 1; k < 7; k++) {
                    if (!conflict[init[j]][k])
                        dp[e][j] = dp[e][j].add(dp[1 - e][k]).mod(
                                new BigInteger(MOD + ""));
                    System.out.println("dp["+e+"]["+j+"]="+dp[e][j]);
                }
            }
        }
        System.out.println("e="+e);
        BigInteger sum = BigInteger.ZERO;
        for (int i = 1; i < 7; i++) {
            sum = sum.add(dp[e][i]).mod(new BigInteger(MOD + ""));
        }
        System.out.println("sum = "+sum);
        System.out.println(sum.multiply(quickpow(4, n)).mod(
                new BigInteger(MOD + "")));
    }

    // 快速冪
    static BigInteger quickpow(int n, int m) {
        BigInteger n1 = new BigInteger(n + "");

        BigInteger t = BigInteger.ONE;
        while (m > 0) {
            if ((m & 1) == 1)
                t = t.multiply(n1).mod(new BigInteger(MOD + ""));
            n1 = n1.multiply(n1).mod(new BigInteger(MOD + ""));
            m >>= 1;
        }
        return t;
    }
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末娃磺,一起剝皮案震驚了整個濱河市薄湿,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌偷卧,老刑警劉巖豺瘤,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異听诸,居然都是意外死亡坐求,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進(jìn)店門晌梨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來桥嗤,“玉大人须妻,你說我怎么就攤上這事》毫欤” “怎么了荒吏?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長师逸。 經(jīng)常有香客問我司倚,道長,這世上最難降的妖魔是什么篓像? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任动知,我火速辦了婚禮,結(jié)果婚禮上员辩,老公的妹妹穿的比我還像新娘盒粮。我一直安慰自己,他們只是感情好奠滑,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布丹皱。 她就那樣靜靜地躺著,像睡著了一般宋税。 火紅的嫁衣襯著肌膚如雪摊崭。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天杰赛,我揣著相機(jī)與錄音呢簸,去河邊找鬼。 笑死乏屯,一個胖子當(dāng)著我的面吹牛根时,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播辰晕,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蛤迎,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了含友?” 一聲冷哼從身側(cè)響起替裆,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎窘问,沒想到半個月后扎唾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡南缓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了荧呐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片汉形。...
    茶點(diǎn)故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡纸镊,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出概疆,到底是詐尸還是另有隱情逗威,我是刑警寧澤,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布岔冀,位于F島的核電站凯旭,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏使套。R本人自食惡果不足惜罐呼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望侦高。 院中可真熱鬧嫉柴,春花似錦、人聲如沸奉呛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽瞧壮。三九已至登馒,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間咆槽,已是汗流浹背陈轿。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留罗晕,地道東北人济欢。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像小渊,于是被迫代替她去往敵國和親法褥。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評論 2 355

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

  • 1酬屉、三角形面積 如【圖1】所示半等。圖中的所有小方格面積都是1。那么呐萨,圖中的三角形面積應(yīng)該是多少呢杀饵? 請?zhí)顚懭切蔚拿?..
    Jdqm閱讀 1,685評論 0 4
  • 簡介 用簡單的話來定義tcpdump,就是:dump the traffic on a network谬擦,根據(jù)使用者...
    保川閱讀 5,956評論 1 13
  • 壘骰子 賭圣atm晚年迷戀上了壘骰子切距,就是把骰子一個壘在另一個上邊,不能歪歪扭扭惨远,要壘成方柱體谜悟。經(jīng)過長期觀察话肖,at...
    徐森威閱讀 1,694評論 2 1
  • 在學(xué)校的日子,天天惦記著假期葡幸。 假期到來了最筒,又開始在家遭嫌棄。 于是蔚叨,想出去打工的念頭就出來了床蜘。 既可以偷偷出去瘋...
    木三米閱讀 473評論 0 4
  • 刀光不依不饒。 跌進(jìn)誰的懷抱蔑水。 午夜戰(zhàn)場大漠荒煙邢锯。 如狂草。 霜降肤粱。 滿城蕭條弹囚。 冷了長亭短橋。 眉間朱砂领曼。 亂世...