Олимпиадный тренинг

Задача . E. Валера и число


Валера — программист. Недавно Валера написал забавную программу. Ниже показан псевдокод этой программы:


//входные данные: целые числа x, k, p
a = x;
for(step = 1; step <= k; step = step + 1){
rnd = [случайное целое число от 1 до 100];
if(rnd <= p)
a = a * 2;
else
a = a + 1;
}

s = 0;

while(остаток от деления a на 2 равен 0){
a = a / 2;
s = s + 1;
}

Теперь Валера интересуется, при заданных x, k и p чему равно математическое ожидание полученного числа s?

Входные данные

В первой строке входных данных задано три целых числа x, k, p (1 ≤ x ≤ 109; 1 ≤ k ≤ 200; 0 ≤ p ≤ 100).

Выходные данные

Выведите требуемое математическое ожидание. Ваш ответ будет считаться правильным, если его абсолютная или относительная погрешность не превышает 10 - 6.

Примечание

Если вы не знакомы с термином математическое ожидание, то вы можете почитать про него по ссылке:

http://ru.wikipedia.org/wiki/Математическое_ожидание


Примеры
Входные данныеВыходные данные
1 1 1 50
1.0000000000000
2 5 3 0
3.0000000000000
3 5 3 25
1.9218750000000

time 2000 ms
memory 256 Mb
Правила оформления программ и список ошибок при автоматической проверке задач

Статистика успешных решений по компиляторам
 Кол-во
С++ Mingw-w645
Комментарий учителя