描述
L國是一個有着優美景色且物產豐富的國家,很多人都喜歡來這里旅游並且喜歡帶走一些紀念品,大神同學也不例外。距離開L國的時間越來越近了,大神同學正在煩惱給她可愛的小伙伴們帶什么紀念品好,現在擺在大神同學面前的有三類紀念品A, B, C可以選擇,每類紀念品各有N種。其中種類為A_i, B_i, C_i的紀念品價值均為i, 且分別有N+1-i個剩余。現在大神同學希望在三類紀念品中各挑選一件然后贈送給她的三名可愛的小伙伴,但是她又不希望恰好挑出來兩件價值相同的紀念品,因為這樣拿到相同價值紀念品的兩位小伙伴就會認為大神同學偏袒另一位小伙伴而不理睬她超過一星期。現在,大神同學希望你買到的三件紀念品能讓三位小伙伴都開心並且不和她鬧別扭,她想知道一共有多少種不同挑選的方法?
因為方案數可能非常大,大神同學希望知道挑選紀念品的方案數模10^9+7之后的答案。
輸入
第一行包括一個數T,表示數據的組數。
接下來包含T組數據,每組數據一行,包括一個整數N。
輸出
對於每組數據,輸出一行“Case x: ”,其中x表示每組數據的編號(從1開始),后接一個數,表示模10^9+7后的選擇紀念品的方案數。
數據范圍
小數據:
1<=T<=10
1<=N<=100
大數據:
1<=T<=1000
1<=N<=10^18
樣例解釋
對於第二組數據,合法的方案有以下幾種,(X,Y,Z)表示選擇了A類紀念品中價值為X的,B類紀念品中價值為Y的,C類紀念品中價值為Z的。
(1,1,1): 3*3*3=27種
(1,2,3): 3*2*1=6種
(1,3,2): 3*1*2=6種
(2,1,3): 2*3*1=6種
(2,2,2): 2*2*2=8種
(2,3,1): 2*1*3=6種
(3,1,2): 1*3*2=6種
(3,2,1): 1*2*3=6種
(3,3,3): 1*1*1=1種
一共27+6+6+6+8+6+6+6+1=72種選擇紀念品的方案
注意,如(1,1,2), (2,3,3), (3,1,3)都因為恰好選擇了兩件價值相同的紀念品,所以並不是一種符合要求的紀念品選擇方法。
- 樣例輸入
-
2 1 3
- 樣例輸出
-
Case 1: 1 Case 2: 72
直接暴搜即可1 //source here 2 #include <stdio.h> 3 4 5 int main() 6 { 7 int T,n; 8 int i,j,k,l; 9 int all; 10 int txxx=0; 11 int tmp=1000000007; 12 scanf("%d",&T); 13 14 for(l=0; l <T; l++) 15 { 16 scanf("%d",&n); 17 all=0; 18 for(i=1; i<=n; i++){ 19 all=all+(n+1-i)*(n+1-i)*(n+1-i); 20 } 21 for(i=1; i<=n; i++){ 22 23 for(j=1; j<=n; j++){ 24 if(i==j)continue; 25 for(k=1; k<=n; k++) 26 { 27 if(k==j || k==i)continue; 28 txxx=(n+1-i)*(n+1-j)*(n+1-k); 29 all+=txxx; 30 all=all%tmp; 31 } 32 } 33 } 34 35 printf("Case %d: %d\n",l+1,all); 36 } 37 return 0; 38 }
