QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#262426 | #5414. Stop, Yesterday Please No More | vp_account | WA | 2ms | 6512kb | C++14 | 1.3kb | 2023-11-23 19:26:08 | 2023-11-23 19:26:08 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
constexpr int M=1005;char s[M*M];
int n,m,k,x,y,ans,len,u,d,l,r,U,D,L,R,a[M][M];
int read(){
int x=0,f=1;char ch=getchar();
while (!isdigit(ch)) {if (ch=='-') f=-1;ch=getchar();}
while (isdigit(ch)) x=x*10+ch-48,ch=getchar();
return x*f;
}
void upd(int x,int y){
int xl=U-x,xr=D-x,yl=L-y,yr=R-y;
xl=max(xl,1);xr=min(xr,n);
yl=max(yl,1);yr=min(yr,m);
if (xl>xr||yl>yr) return ;
a[xl][yl]++;a[xl][yr+1]--;a[xr+1][yl]--;a[xr+1][yr+1]++;
}
void solve(){ ans=0;
n=read();m=read();k=read();
scanf("%s",s+1);len=strlen(s+1);
U=u=L=l=1;D=d=n;R=r=m;
for (int i=1;i<=len;i++){
if (s[i]=='D') u--,d--;
else if (s[i]=='U') u++,d++;
else if (s[i]=='R') l--,r--;
else if (s[i]=='L') l++,r++;
U=max(U,u);D=min(D,d);
L=max(L,l);R=min(R,r);
}
if (U>D||L>R) return printf("%d\n",k?0:n*m),void();
k=(D-U+1)*(R-L+1)-k;
if (k<0) return puts("0"),void();
map<pair<int,int>,bool>mp;
for (int i=1;i<=n;i++)
for (int j=1;j<=m;j++)
a[i][j]=0;
x=y=0;upd(0,0);
for (int i=1;i<=len;i++){
x+=(s[i]=='U')-(s[i]=='D');
y+=(s[i]=='L')-(s[i]=='R');
if (!mp[{x,y}]) mp[{x,y}]=1,upd(x,y);
}
for (int i=1;i<=n;i++)
for (int j=1;j<=m;j++)
ans+=(a[i][j]+=a[i-1][j]+a[i][j-1]-a[i-1][j-1])==k;
printf("%d\n",ans);
}
int main(){int T=read();
while (T--) solve();
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1ms
memory: 3784kb
input:
3 4 5 3 ULDDRR 4 5 0 UUUUUUU 4 5 10 UUUUUUU
output:
2 20 0
result:
ok 3 number(s): "2 20 0"
Test #2:
score: -100
Wrong Answer
time: 2ms
memory: 6512kb
input:
1060 19 12 0 UDLDDUUUUDDDLLRDUDUURULUUUDRDUDRDRLRLRLULULLLDLDDRLUUUURUUUDDRLLRUUUDULURUULLRDRLRDDURDUUURRRLURLRUULRRUDURDLUUURDLURDDLUUURDDRLLURRDLRUDLRDRLLRRDRDDLDRURRRLUDULLLRUUDLRRURRDLLRRRDLLRDDDLRLRURURDDDL 11 1 0 UR 3 18 33 UDRLR 17 11 132 RLDRDLDRUU 6 10 13 UULUDDLRDLUUDLDD 1 15 0 D 6 20 50 D...
output:
228 11 19 0 18 15 34 240 15 0 0 13 14 18 26 16 1 19 108 8 1 2 3 7 0 29 14 21 0 8 1 9 13 5 320 3 7 3 0 0 12 0 11 0 0 14 0 22 36 51 23 5 6 3 11 48 28 8 7 22 49 13 10 2 0 4 18 44 0 14 9 0 4 30 14 99 105 5 14 17 0 66 10 11 28 52 34 8 33 14 0 90 0 0 11 3 48 30 36 12 0 30 7 8 3 11 16 45 20 34 0 20 0 21 0 ...
result:
wrong answer 3rd numbers differ - expected: '20', found: '19'