QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#745023 | #9746. 平方根 | ggghe | WA | 7ms | 11824kb | C++20 | 815b | 2024-11-14 01:27:31 | 2024-11-14 01:27:31 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
const int N = 1'000'010;
double dp[N];
int main() {
string s;
cin >> s;
double ans = 0.0;
dp[1] = 1.0;
for (int i = 1; i < N; ++i) {
dp[i] = max(sqrt(i * 1.0), dp[i]);
if (i * 2 + 1 < N) {
dp[i * 2 + 1] = max(dp[i * 2 + 1], 2.0 * dp[i]);
}
if (i * 2 < N) {
dp[i * 2] = max(dp[i * 2], dp[i] + dp[i - 1]);
}
}
int n = s.length();
int i = 0;
while (i < n) {
if (s[i] == '0') {
i++;
continue;
}
int st = i;
while (i < n && s[i] == '1') {
i++;
}
int len = i - st;
ans += dp[len];
}
printf("%.6f\n", ans);
return 0;
}
详细
Test #1:
score: 0
Wrong Answer
time: 7ms
memory: 11824kb
input:
1100110111
output:
4.828427
result:
wrong answer 1st numbers differ - expected: '4.8284271', found: '4.8284270', error = '0.0000000'