#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
double rs, rb;
double solve(double S0, int n, long long k) {
if (n == 0)
return S0;
// k가 전체 과자 개수보다 크다면 작은 과자조각으로 반환
if (k > (1<<n)/2) {
return solve(S0+rs, n-1, k/2);
}
// 아니면 큰 조각으로 반환
return solve(S0+rb, n-1, k);
}
int main() {
long long a, b, n, k;
cin >> a >> b >> n >> k;
if (a > b) swap(a, b);
rs = log((double)a*a / (double)(a*a + b*b));
rb = log((double)b*b / (double)(a*a + b*b));
double S0 = log(a*b / 2.0);
printf("%.12f\n", solve(S0, n, k));
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
0 ms |
1828 KB |
Output isn't correct |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Halted |
0 ms |
0 KB |
- |