QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#865783 | #5603. Three Dice | LaVuna47 | AC ✓ | 15ms | 3968kb | C++20 | 2.6kb | 2025-01-21 22:39:24 | 2025-01-21 22:39:24 |
Judging History
answer
//A tree without skin will surely die.
//A man without face is invincible.
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
#include <bits/stdc++.h>
#define all(x) (x).begin(), (x).end()
#define rall(x) (x).rbegin(), (x).rend()
#define sz(S) ((int)S.size())
#define FOR(i, st_, n) for(int i = st_; i < n; ++i)
#define RFOR(i, n, end_) for(int i = (n)-1; i >= end_; --i)
#define x first
#define y second
#define pb push_back
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<ll, ll> pll;
typedef pair<int, int> pii;
typedef pair<double, double> pdd;
typedef unsigned long long ull;
typedef long double LD;
typedef pair<ull, ull> pull;
using namespace __gnu_pbds;
typedef tree<ll, null_type, less<>, rb_tree_tag, tree_order_statistics_node_update> ordered_set;
using namespace std;
#ifdef ONPC
mt19937 rnd(228);
#else
mt19937 rnd(chrono::high_resolution_clock::now().time_since_epoch().count());
#endif
/*
a f t
c o g
r
aft
cog
far
irk
kit
yes
tau
rag
own
uke
via
*/
vector<string> a;
// ac fo tgr
vector<int> M;
bool bf(int p, int s1, int s2, int s3)
{
if((s1 & s2) != 0 || (s2 & s3) != 0 || (s1 & s3) != 0)
return false;
if(__popcount(s1)>6 || __popcount(s2)>6 || __popcount(s3) > 6)
return false;
if(p==-1)
{
M={s1,s2,s3};
return true;
}
vector<int> P={0,1,2};
do
{
if(bf(p-1, s1 | (1 << (a[p][P[0]]-'a')), s2 | (1 << (a[p][P[1]]-'a')), s3 | (1 << (a[p][P[2]]-'a'))))
return true;
} while(next_permutation(all(P)));
return false;
}
int solve()
{
int n;
if(!(cin>>n))return 1;
a=vector<string>(n);
FOR(i,0,n)cin>>a[i];
bool has_chance=true;
FOR(i,0,n)
{
if(sz(set<char>(all(a[i]))) != sz(a[i]))
has_chance=false;
}
if(has_chance && bf(n-1,0,0,0))
{
set<int> S;
FOR(i,0,3)
{
FOR(j,0,26)
{
if((M[i]>>j)&1) S.insert(j);
}
}
FOR(i,0,3)
{
FOR(j,0,26)
{
if(__popcount(M[i])<6 && S.find(j)==S.end())
{
M[i] |= (1 << j);
S.insert(j);
}
}
}
FOR(i,0,3)
{
FOR(j,0,26)
{
if((M[i]>>j)&1)cout<<char('a'+j);
}
cout<<' ';
}
cout<<'\n';
}
else
{
cout<<"0\n";
}
return 0;
}
int32_t main()
{
ios::sync_with_stdio(0);
cin.tie(0);
int TET = 1e9;
//cin >> TET;
for (int i = 1; i <= TET; i++)
{
if (solve())
{
break;
}
#ifdef ONPC
cout << "__________________________" << endl;
#endif
}
#ifdef ONPC
cerr << endl << "finished in " << clock() * 1.0 / CLOCKS_PER_SEC << " sec" << endl;
#endif
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 3712kb
input:
3 lad fin sly
output:
abcefs ghijkl dmnopy
result:
ok correct
Test #2:
score: 0
Accepted
time: 0ms
memory: 3712kb
input:
1 dad
output:
0
result:
ok impossible
Test #3:
score: 0
Accepted
time: 0ms
memory: 3712kb
input:
11 aft cog far irk kit yes tau rag own uke via
output:
beortv fgiuwy acdkns
result:
ok correct
Test #4:
score: 0
Accepted
time: 0ms
memory: 3712kb
input:
20 aah aal aas aba abo abs aby ace act add ado ads adz aff aft aga age ago aha aid
output:
0
result:
ok impossible
Test #5:
score: 0
Accepted
time: 15ms
memory: 3584kb
input:
23 abc acb bac bca cab cba abd adb bad bda dab dba acd adc cad cda dac dca fgh ijk lmn opq rst
output:
0
result:
ok impossible
Test #6:
score: 0
Accepted
time: 0ms
memory: 3712kb
input:
24 abc bcd cde def efg fgh ghi hij ijk jkl klm lmn mno nop opq pqr qrs rst stu tuv uvw vwx wxy xyz
output:
0
result:
ok impossible
Test #7:
score: 0
Accepted
time: 1ms
memory: 3584kb
input:
121 lax tog taj fun get jar fez own now gut gul ark fax new meg fen fog log lez gum kor leg not rug fug lag kit urn gal nam gar jew rex rin ant gam mun jam nil gem kir ilk jut ern man mon awn mig mix wag erg gor fig run nim raj fix elk nom wig gat nor jow fag jaw kaf rig fin kat rag mag won wog wan ...
output:
gjknxz aeiouy flmrtw
result:
ok correct
Test #8:
score: 0
Accepted
time: 0ms
memory: 3584kb
input:
149 pic twa cub wag spa til two pyx pis tew vug cig pul vig pol tow tis sub pew sty eld gas pes guv bal dol lob sot sap cob ply tic taw wit bow lad gal cup cep pax lab bys sup psi pox ops tel dex veg lop vat uts ods ups wiz lit gox wud cad sod cud dev paw pac dow wig gul zax sob set lag lip doc bos ...
output:
bdgptz aeiouy clsvwx
result:
ok correct
Test #9:
score: 0
Accepted
time: 0ms
memory: 3712kb
input:
97 fub tav seg box tas ski bin six syn fas sag neb sot jog gab van vug zax ban fob ons ask zit jot zin jin fiz nob jut fez beg vet sox kos gib sit sat bun bot son ifs ens but fib ins bug big sen vig tab sex zig ben sin efs kas kob nos zek nab qat xis gob guv set its bag sun veg zag uns tis sty ska n...
output:
aeiouy fgkntx bjqsvz
result:
ok correct
Test #10:
score: 0
Accepted
time: 0ms
memory: 3584kb
input:
150 jug nit hen ant imp men ply pam pah awn jig god pal pet gan put jet dol zag tap ted lip dah lez tad pom dom dig pul hup mod edh poh dow lop old wan hap wed gin tup paw tod wiz nil ton nom tan hun hin apt mop daw pol ump noh pew pot wap hid nut map lap gun tun nam gip won nag eng wad own zit mon ...
output:
ghlmtw aeiouy djnpqz
result:
ok correct
Test #11:
score: 0
Accepted
time: 0ms
memory: 3840kb
input:
259 bog ant gan urn eng pit pig dam bid nod dap rib pul ens bot dim fur ops fad ugh fag bod hes lib she spy rep rum ash mug lin mig tan het rif sop pur gap bet pal mud big dah bit gun fro arm rub dib rap fed oms bas alb aft lip mol ins fas gum sob mod end ref sib dip arf mos ems hut nor ifs bra bud ...
output:
dglrst aeiouy bfhmnp
result:
ok correct
Test #12:
score: 0
Accepted
time: 0ms
memory: 3584kb
input:
260 bog ant gan urn eng pit pig dam bid nod dap rib pul ens bot dim fur ops fad ugh fag bod hes lib she spy rep rum ash mug lin mig tan het rif sop pur gap bet pal mud big dah bit gun fro arm rub dib rap fed oms bas alb aft lip mol ins fas gum sob mod end ref sib dip arf mos ems hut nor ifs bra bud ...
output:
0
result:
ok impossible
Test #13:
score: 0
Accepted
time: 1ms
memory: 3968kb
input:
1000 lgk nur wnm czr zuk une kob elg whc evn vlx woz mne gnp odp vkz xgz wdc npu hgk ged mwd hvx crn zcr vnp uze xbv brv bve okl bwg kno xgl oeh dec kvh nvp mpz hwc pbc ngk egz zpv zme ubx hgr xbo bgw brc rmd ubp xdc mxh hxc ebu vpz bgk dwg dve deu obp ohw ubx cxl edo zkv mbr mhe kbo zwu zwv gnk rhv...
output:
ekprwx cgmouv bdhlnz
result:
ok correct
Test #14:
score: 0
Accepted
time: 0ms
memory: 3840kb
input:
1000 sfp fbk nfw pfk qdk odm wgv kvt nwu mgw ucs gcq gvw kjd mda fod psu jto aqb pmg jba tja kdj usd fbs gqd ckq uod vco mkc djs sbj psj boj mws obu bau bgf qbn atu ntv ncf tof jts cmg tku fac dkf pfs pkf pqa nuw ojc svp otm sbf jwk mac vsp jbs jab dam omt udo jdo dsu joc auw tqs stf vgt cgu psu nup...
output:
bcdptw agknos fjmquv
result:
ok correct
Test #15:
score: 0
Accepted
time: 0ms
memory: 3968kb
input:
1000 zjh lxd ftq xkb xkb oqt clf yce fjq ylc vqy ckv cke ovh fvx xdb qft dwl wjo kqv yei vfi tcf wjd tck ibz lck jcf qvz lzq ezx yvw jif tfq fxe vxz ekc tfi tiz ilz fjw yxj yvx hze dhe ibf ehk qzl kbc yvc oxb oil ijf vfw bkh lhd bhz dhe ybc ybh eyq dbw vxf xlz jwk zjx xkt ivd bio feh yjx ywb wkl xjd...
output:
bejltv chiqwx dfkoyz
result:
ok correct
Test #16:
score: 0
Accepted
time: 0ms
memory: 3712kb
input:
1000 epn vpq xud gjq pxr hgt ezo gfs okk ukb rne iof eko flg yzz sck qwa zks bep uzh onw nfs ram tfp ctr ahw hrz fxx jgb izx gvs afn cii vbk wzx lkb sbl dga jpi nlv eon svd ioo zas bgh zdj elm aip kmf fta pmh vwr dsj gib yjv hgx ffx tyn crf yao vqm zbm bzu cay rkt jie pgn jms cpd jhd moz ymc ogc bve...
output:
0
result:
ok impossible
Test #17:
score: 0
Accepted
time: 1ms
memory: 3840kb
input:
1000 dzq bjt xwu pwy mba ekg pyo mqc nqo xrh ptt ayg ogv uga qop olo ohw rrm ekg vwq ilv emx lld ibf hpd ffn kei wop mxx quw zgn otm fcu ehs mnl evl lsk ocr bkg bpc zzx dcm jpx yak yuc qzz ktl ifb blo ktn qpm gtb nhp pao ugp qow hgt wqi axf rjz tnl rtm nyw bmx nfe rfu wru mpw wmm wzy jgm icz szd elb...
output:
0
result:
ok impossible
Test #18:
score: 0
Accepted
time: 1ms
memory: 3584kb
input:
1000 xzy hta jca xfn hjh ige fch cdl tzj gyg qsg ebt irn lys jgs bpe zog mkv ggb wos faa arr sqy cjc bbz wld rkx hdk gob ars frk ltj dzw ilg gxs ubm edf uur yfr fkv pma tek qqe tgn wwh low fit tzz txv yhq xix mnb ner jup nrl bim iwu rgh ohv mmn utv zil wqd vee ajh jwq eau rrh bdc zzm zfk ago bwi cwi...
output:
0
result:
ok impossible