201312 4 有趣的數

2021-10-02 10:27:15 字數 2171 閱讀 9416

問題描述

我們把乙個數稱為有趣的,當且僅當:

1. 它的數字只包含0, 1, 2, 3,且這四個數字都出現過至少一次。

2. 所有的0都出現在所有的1之前,而所有的2都出現在所有的3之前。

3. 最高位數字不為0。

因此,符合我們定義的最小的有趣的數是2013。除此以外,4位的有趣的數還有兩個:2031和2301。

請計算恰好有n位的有趣的數的個數。由於答案可能非常大,只需要輸出答案除以1000000007的餘數。

輸入格式

輸入只有一行,包括恰好乙個正整數n (4 ≤ n ≤ 1000)。

輸出格式

輸出只有一行,包括恰好n 位的整數中有趣的數的個數除以1000000007的餘數。

樣例輸入

4樣例輸出

3

#include

#include

using

namespace std;

long

long dps[4]

;//因為題目中明確可能性會超過十億零七,所以用long long資料型別儲存,該資料型別取值範圍為-2^63~2^63-1,可以承受

long

long dpsq[

1001][

2][2

][2]

[2][

2][4

];long

longdp(

int n,

bool flag,

int branch)

else

else

if(dps[2]

==0) dps[0]

++;ans+=dp

(n-1

,false

,branch)

; dps[0]

--;}else

if(dps[0]

==0) dps[2]

++;ans+=dp

(n-1

,false

,branch)

; dps[2]

--;}}

} ans %

=1000000007

; dpsq[n]

[flag0]

[flag1]

[flag2]

[flag3]

[flag]

[branch]

=ans;

return ans;

}int

main()

基本思路是動態規劃,因為考慮到最終結果肯定超過10億,然後如果用現有計數器乙個個加的方法,要至少加10億次,所以如果不用動態規劃肯定超時。

然後對於乙個n位有趣的數,遞迴考慮的話

可以由乙個n-1位有趣的數加3或者1組成

可以由乙個n-1位缺乏1或者缺乏3但是滿足規則順序的數加上1或者3組成

在這種情況下,結合動態規劃的思想,我要考慮把遞迴函式的結果儲存起來,然後再考慮遞迴過程

這裡有點些許複雜的是n-1位非遞迴的數的遞迴思路,這裡比較容易推出,畫遞迴樹可以清晰得到,不贅述

然後結合遞迴樹,得到整個**的遞迴過程

遞迴出口:

遞迴過程

#include

#include

#include

#include

#include

#include

#include

using

namespace std;

long

long f[

2000][

3][2

];//因為題目中明確可能性會超過十億零七,所以用long long資料型別儲存,該資料型別取值範圍為-2^63~2^63-1,可以承受

intdp

(int n,

int p1,

int p3)

else

return now;

} now =0;

if(p1 ==0)

else

if(p1 ==1)

else

if(p3 ==0)

else

now %

=1000000007;}

intmain()

201312 4 有趣的數

試題編號 201312 4 試題名稱 有趣的數 時間限制 1.0s 記憶體限制 256.0mb 問題描述 問題描述 我們把乙個數稱為有趣的,當且僅當 1.它的數字只包含0,1,2,3,且這四個數字都出現過至少一次。2.所有的0都出現在所有的1之前,而所有的2都出現在所有的3之前。3.最高位數字不為0...

CSP 2013 12 4 有趣的數

問題分析 這是乙個計算問題,關鍵在於找到乙個遞推式。只要找到乙個遞推式,問題就解決了。有時候這類問題也用dp 動態規劃 來解決。根據題意,有趣的數滿足以下約束條件如下 1.只包含數字0 1 2和3 2.0 1 2和3各自至少出現一次 3.所有的0都出現在1之前 4.所有的2都出現在3之前 5.最高位...

CCF 201312 4 有趣的數

時間限制 1.0s 記憶體限制 256.0mb 我們把乙個數稱為有趣的,當且僅當 1.它的數字只包含0,1,2,3,且這四個數字都出現過至少一次。2.所有的0都出現在所有的1之前,而所有的2都出現在所有的3之前。3.最高位數字不為0。因此,符合我們定義的最小的有趣的數是2013。除此以外,4位的有趣...