結果
問題 |
No.144 エラトステネスのざる
|
ユーザー |
![]() |
提出日時 | 2016-09-28 19:53:05 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 44 ms / 2,000 ms |
コード長 | 706 bytes |
コンパイル時間 | 779 ms |
コンパイル使用メモリ | 64,492 KB |
実行使用メモリ | 11,552 KB |
最終ジャッジ日時 | 2024-11-21 08:24:51 |
合計ジャッジ時間 | 1,717 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 17 |
ソースコード
#include <iostream> #include <algorithm> #include <vector> #include <queue> #include <cstdio> #include <set> 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; }