QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#752825 | #5593. Food Processor | anyan26 | WA | 1ms | 4040kb | C++17 | 954b | 2024-11-16 09:59:55 | 2024-11-16 09:59:58 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
double nxt(double size, double want, double div2){
return (log2(size) - log2(want)) * (double)div2;
}
int main(){
ios_base::sync_with_stdio(false);
cin.tie(nullptr);
//sort by t
double s, t;int n; cin >> s >> t >> n;
pair<double, double> process[n];
for(int i = 0; i < n; i++){ //hour, blade size
cin >> process[i].second >> process[i].first;
}
sort(process, process+n);
int cur = n;
double ret = 0; bool can = false;
if(process[n-1].second <= s){
while (s > t){
can = true;
while(cur > 0 && process[cur-1].second >= s)cur--;
int goal = t;
if(cur != 0)goal = process[cur-1].second;
ret += nxt(s, goal, process[cur].first);
s = goal;
}
}
if(can)cout << fixed << setprecision(10) << ret << "\n";
else cout << -1 << "\n";
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1ms
memory: 3972kb
input:
10 1 2 10 10 4 5
output:
23.2192809489
result:
ok found '23.21928', expected '23.21928', error '0.00000'
Test #2:
score: 0
Accepted
time: 0ms
memory: 3776kb
input:
10000 9999 1 10000 1
output:
0.0001442767
result:
ok found '0.00014', expected '0.00014', error '0.00000'
Test #3:
score: -100
Wrong Answer
time: 0ms
memory: 4040kb
input:
10 1 2 8 10 4 5
output:
20.0000000000
result:
wrong answer 1st numbers differ - expected: '-1.00000', found: '20.00000', error = '21.00000'