#include #include #include #include #include #include using namespace std; #define rep(i,n) for(int i=0;i<(n);i++) const int INF = 1e9; int n; double p; //dp[i] := i番目の数が、リストに残っている確率 double dp[1000100]; int main(void){ cin >> n >> p; double q = 1.0 - p; //q := 消されない確率 rep(i, 1000100) dp[i] = 1.0; for (int x = 2; x <= n; ++x){ for (int i = 2; i <= n; ++i){ if(x * i > n) break; dp[x * i] *= q; // printf("dp[%d] = %.6f\n", x * i, dp[x * i]); } } double ret = 0; //線形性から計算 for (int i = 2; i <= n; ++i){ ret += dp[i] * 1.0; } printf("%.9f\n", ret); return 0; }