# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
338485 | 2020-12-23T09:12:03 Z | beksultan04 | 아름다운 순열 (IZhO12_beauty) | C++14 | 13 ms | 3052 KB |
#include <bits/stdc++.h> using namespace std; #define pii pair<int,int> #define OK puts("OK"); #define NO puts("NO"); #define YES puts("YES"); #define fr first #define sc second #define ret return #define scan1(a) scanf("%d",&a); #define scan2(a,b) scanf("%d %d",&a, &b); #define scan3(a,b,c) scanf("%d %d %d",&a,&b,&c); #define all(s) s.begin(),s.end() #define allr(s) s.rbegin(),s.rend() #define pb push_back #define sz(v) (int)v.size() #define endi puts(""); const int N = 1048579,INF=1e9+7; int q[N],dp[N][21],tr[30],dv[30],vis[N][21],g[50][50],n; int troich(int x){ int ans=0; while (x > 0){ if (x%3==1)ans++; x /=3; } ret ans; } int dvoich(int x){ int ans=0; while (x > 0){ if (x%2==1)ans++; x /=2; } ret ans; } bool is(int a,int b){ ret (tr[a] == tr[b] || dv[a] == dv[b]); } int rec(int x,int j){ if (x == (1<<n)-1)ret 1; if (vis[x][j]==1)ret dp[x][j]; vis[x][j]=1; int ans=0,i; for (i=0;i<n;++i){ if (i == j || (x&(1<<i)) || g[i][j] == 0)continue; ans += rec(x+(1<<i),i); } ret dp[x][j]=ans; } main(){ int i,j,s,cnt=1; scan1(n) for (i=0;i<n;++i){ scan1(q[i]) tr[i]=troich(q[i]); dv[i]=dvoich(q[i]); } for (i=0;i<n;++i){ for (j=i+1;j<n;++j){ if (is(i,j)){ g[i][j]=1; g[j][i]=1; } } } int ans=0; for (i=0;i<n;++i){ ans+=rec((1<<i),i); } cout <<ans; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 364 KB | Output is correct |
2 | Correct | 1 ms | 364 KB | Output is correct |
3 | Correct | 1 ms | 364 KB | Output is correct |
4 | Correct | 1 ms | 364 KB | Output is correct |
5 | Correct | 1 ms | 364 KB | Output is correct |
6 | Correct | 1 ms | 492 KB | Output is correct |
7 | Correct | 1 ms | 492 KB | Output is correct |
8 | Correct | 1 ms | 492 KB | Output is correct |
9 | Correct | 1 ms | 492 KB | Output is correct |
10 | Correct | 1 ms | 492 KB | Output is correct |
11 | Incorrect | 13 ms | 3052 KB | Output isn't correct |
12 | Halted | 0 ms | 0 KB | - |