結果
| 問題 | No.144 エラトステネスのざる |
| コンテスト | |
| ユーザー |
srup٩(๑`н´๑)۶
|
| 提出日時 | 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;
}
srup٩(๑`н´๑)۶