-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathngon.c
48 lines (45 loc) · 888 Bytes
/
ngon.c
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#include<stdio.h>
#define MAX 1010
#define MODULO 1000000007
int main()
{
int test_cases,i,a,b;
int sides,points[MAX],precalculate[MAX];
unsigned long long int result[MAX][MAX],temp;
for(scanf("%d",&test_cases);test_cases>0;test_cases--)
{
scanf("%d",&sides);
for(i=0;i<sides;i++)
{
scanf("%d",&points[i]);
precalculate[i]=points[i]*(points[i]-1)/2;
}
result[0][0]=1;
for(a=1;a<=sides;a++)
{
result[a][0]=1;
result[0][a]=0;
}
for(a=1;a<=sides;a++)
{
for(b=1;b<=sides;b++)
{
if(b>2*a)
{
result[a][b]=0;
}
else
{
result[a][b]=(result[a-1][b]+result[a-1][b-1]*points[a-1]);
if(b>1)
{
temp=result[a-1][b-2]*precalculate[a-1];
result[a][b]=(result[a][b]+temp)%MODULO;
}
}
}
}
printf("%lld\n",result[sides][sides-1]);
}
return 0;
}