結果
問題 | No.611 Day of the Mountain |
ユーザー |
![]() |
提出日時 | 2017-12-22 12:14:10 |
言語 | cLay (20241019-1) |
結果 |
AC
|
実行時間 | 1,169 ms / 2,017 ms |
コード長 | 553 bytes |
コンパイル時間 | 3,172 ms |
コンパイル使用メモリ | 181,240 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-05 12:51:12 |
合計ジャッジ時間 | 8,693 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 9 |
ソースコード
#define MD 201712111 int h,w,t[320]; char a[320][320]; mint d[1<<18],*u=d,*v=d+(1<<17); { rd(h,w,a(h)); if(w>h){ rep(y,w)rep(x,y)swap(a[y][x],a[x][y]); swap(w,h); } u[0]=1; rep(y,h)rep(x,w){ int ty=(y?t[x]:1<<30); int tx=(x?t[x-1]:1<<30); rep(b,1<<w){ bool b0=1&b>>x; bool b1=1&b>>x-1; v[b]=(ty<tx||ty>tx&&b0==b1||ty==tx&&b0<=b1)*(u[b]+(ty>tx||ty==tx&&!b1)*u[b^1<<x]); if(b0&&a[y][x]=='?'){ v[b]+=(v[b-(1<<x)]+v[b])*8; } } swap(u,v); t[x]=(x+y?min(ty,tx):0)+a[y][x]%16%14; } wt(t[w-1]); wt(sum(u(1<<w-1))); }