#include #include int main(void) { int n, x, i; float p, mean = 0; float *list_of_koho; float *list_of_sosu; scanf("%d %f", &n, &p); list_of_koho = (float *)malloc( sizeof( float ) * (n+1) ); list_of_sosu = (float *)malloc( sizeof( float ) * (n+1) ); for (i = 2; i <= n; i++) { list_of_koho[i] = 1; list_of_sosu[i] = 0; } for (x = 2; x <= n; x++) { list_of_sosu[x] = list_of_koho[x]; list_of_koho[x] = 0; for (i = 2; x*i <= n; i++) list_of_koho[x*i] -= list_of_koho[x*i] * p; } for (i = 2; i <= n; i++) mean += list_of_sosu[i]; printf("%f\n", mean); return 0; }