// #pragma GCC target("avx") // CPU 処理並列化 // #pragma GCC optimize("O3") // CPU 処理並列化 // #pragma GCC optimize("unroll-loops") // 条件処理の呼び出しを減らす #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; const long long mod=1000000007; const long long inf=mod*mod; const long long d2=(mod+1)/2; const double EPS=1e-10; const double INF=1e+10; const double PI=acos(-1.0); const int C_SIZE = 3100000; const int UF_SIZE = 210000; namespace{ long long fact[C_SIZE]; long long finv[C_SIZE]; long long inv[C_SIZE]; long long Comb(int a,int b){ if(a +EPS) ? +1 : 0; } int UF[UF_SIZE]; void init_UF(int n){ for(int i=0;iUF[b])swap(a,b); UF[a]+=UF[b];UF[b]=a; } } // ここから編集しろ long long p[310][310]; long long q[310]; long long r[310]; int Q[310]; int R[310]; int main(){ int a,b;scanf("%d%d",&a,&b); for(int i=0;i=0){ ret+=q[i]; Q[i]=1; for(int j=0;j=0){ ret+=r[i]; R[i]=1; for(int j=0;j=0){ Q[i]=R[j]=1; ret+=q[i]+r[j]+p[i][j]; for(int k=0;k