QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#274644 | #7744. Elevator | whsyhyyh | WA | 35ms | 4796kb | C++14 | 1.5kb | 2023-12-03 19:37:25 | 2023-12-03 19:37:26 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
#define LL long long
const int M=1e5+5;
int T;
int n;
LL k;
struct info {
int c,w,f;
bool operator <(const info &_)const {
return f>_.f;
}
}p[M];
int stk[M];
int main() {
scanf("%d",&T);
while(T--) {
scanf("%d%lld",&n,&k);
for(int i=1; i<=n; ++i)
scanf("%d%d%d",&p[i].c,&p[i].w,&p[i].f);
sort(p+1,p+n+1);
int top=0;
for(int i=1; i<=n; ++i)
if((p[i].c&1)&&p[i].w==1)stk[++top]=p[i].f;
LL now=k/2;
int L=1,Mx=0;
LL ans=0;
for(int i=1; i<=n; ++i) {
if(now==k/2)Mx=p[i].f;
if(p[i].w==1)p[i].c/=2;
if(p[i].c<=now)now-=p[i].c;
else {
ans+=Mx;
p[i].c-=now;
ans+=1LL*p[i].f*(p[i].c/(k/2));
p[i].c=p[i].c%(k/2);
now=k/2-p[i].c;
if(p[i].c)Mx=p[i].f;
}
now=now*2;
while(L<=top&&stk[L]==p[i].f) {
if(now==k)Mx=p[i].f;
now--;
if(now==0)ans+=Mx,now=k;
++L;
}
if((now&1)&&L<=top) {
now--;
if(now==0)ans+=Mx,now=k;
++L;
}
if(i==n&&now!=k)ans+=Mx;
now/=2;
//cout<<"---"<<now<<" "<<Mx<<" "<<L<<" "<<ans<<" "<<p[i].f<<endl;
}
printf("%lld\n",ans);
}
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 1ms
memory: 3644kb
input:
2 4 6 1 1 8 7 2 5 1 1 7 3 2 6 8 1200000 100000 1 100000 100000 1 12345 100000 2 100000 100000 2 12345 100000 1 100000 100000 1 12345 100000 2 100000 100000 2 12345
output:
24 100000
result:
ok 2 lines
Test #2:
score: -100
Wrong Answer
time: 35ms
memory: 4796kb
input:
5501 8 104 5 2 3 6 2 4 5 2 3 6 2 9 8 2 4 2 1 3 7 2 4 8 2 8 1 290 3 1 1 12 12 6 1 2 1 2 2 1 1 2 1 2 4 6 1 1 1 2 5 6 1 4 4 1 4 6 2 4 6 2 5 4 2 5 4 1 4 5 334 1 1 4 1 2 3 4 2 1 5 1 1 2 1 2 13 218 5 2 3 5 1 4 1 2 1 1 2 5 3 2 2 1 1 3 4 2 2 1 2 5 2 2 1 2 1 5 3 2 1 5 2 1 1 1 4 10 260 7 2 1 5 1 1 5 2 4 6 1 6...
output:
9 1 23 4 5 7 1 3 9 6 1 10 4 9 17 6 4 1 8 5 5 7 1 3 23 6 3 3 2 2 2 3 8 1 5 6 9 11 147 7 10 2 7 7 8 6 5 5 1 7 3 5 10 7 7 10 8 1 4 2 3 9 1 5 2 9 1 6 7 7 6 10 18 8 10 4 10 9 2 8 3 5 9 3 6 5 3 2 6 1 3 2 2 1 6 9 6 3 4 8 9 9 2 6 1 2 6 7 5 2 5 21 8 1 2 3 4 9 3 4 6 5 9 6 1 7 3 7 3 2 2 8 7 3 5 9 7 10 7 3 2 4 ...
result:
wrong answer 257th lines differ - expected: '3', found: '2'