QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#624960#6423. Fireworkslir_nutTL 1ms3912kbC++141.2kb2024-10-09 17:00:332024-10-09 17:00:34

Judging History

你现在查看的是最新测评结果

  • [2024-10-09 17:00:34]
  • 评测
  • 测评结果:TL
  • 用时:1ms
  • 内存:3912kb
  • [2024-10-09 17:00:33]
  • 提交

answer

#include <iostream>
#include <cstdio>
#include <utility>
#include <algorithm>
#include <cstring>
#include <vector>
#include <map>
#include <queue>
#include <cmath>
#include <set>

#define test
#ifndef test
    freopen("in.in", stdin);
#endif

#define rint register int
#define ll long long
#define P pair<int, int> 
const int N = 2e5+5;

using namespace std;
int n, m, p;
long double qpow(long double a, int x){
    long double ans = 1;
    while(x){
        if(x&1) ans*=a;
        a*=a;
        x>>=1;
    }
    return ans;
}
long double val(int k){
    long double ans = 1 - qpow(1-(long double)p/10000, k);
    ans /= (n * k + m);
    return ans;
}

void solution(){
    scanf("%d%d%d", &n, &m, &p);
    int l = 1, r = 2e9, eps = 1, lm, rm, mid;
    while(r - l > eps){
        mid = (l + r) / 2;
        lm = mid - eps;
        rm = mid + eps;
        if(val(lm) < val(rm)) l = mid;
        else r = mid;
    }
    long double ans = max(max(val(max(l-1, 1)), val(l)), max(val(l+1), val(l+2)));
    printf("%.10lf", (double)(1/ans));
}

int main(){
    test
    int t = 1;
    scanf("%d", &t);
    while (t--){
        solution();
        if(t) printf("\n");
    }
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 3904kb

input:

3
1 1 5000
1 1 1
1 2 10000

output:

4.0000000000
10141.5852891136
3.0000000000

result:

ok 3 numbers

Test #2:

score: 0
Accepted
time: 0ms
memory: 3912kb

input:

20
10 27 2855
79 59 6888
65 72 7725
78 50 2888
31 21 5759
41 58 6619
47 27 3881
35 55 5095
77 7 6028
17 89 1792
84 60 8604
58 44 4923
88 27 3824
54 63 1482
19 42 5366
93 76 97
100 99 8660
96 36 4343
90 56 9515
24 44 9922

output:

89.7298056505
200.3484320557
177.3462783172
416.8398778004
90.2934537246
149.5694213627
190.6725070858
164.6015211156
139.3497013935
275.1331102484
167.3640167364
207.1907373553
300.7322175732
589.0588489505
101.8770282124
10796.8872669046
229.7921478060
303.9373704812
153.4419337888
68.5345696432

result:

ok 20 numbers

Test #3:

score: -100
Time Limit Exceeded

input:

10
954269343 987322500 9806
916720797 981711601 9728
902477101 957414437 9250
967013471 988735825 9674
985383693 926528961 9411
970653208 917703218 9331
998423148 911924940 9283
986159007 902133513 9759
953796828 947934512 9959
995334734 931874197 9944

output:


result: