Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/34: Рейтинг темы: голосов - 34, средняя оценка - 4.91
0 / 0 / 0
Регистрация: 23.09.2021
Сообщений: 4

Задача на python и теорию вероятностей

12.10.2021, 21:49. Показов 6841. Ответов 11

Студворк — интернет-сервис помощи студентам
У вас есть n монет. Если подбросить j- ю монету с вероятностью p(i) выпадет орел, а с вероятностью (1-p(i)) решка. Проведем эксперимент. Подбросим каждую из n монет один раз и посчитаем количество выпавших орлов. Для всех i от 0 до n включительно найдите вероятность выпадения ровно i орлов.
На вход подаются n от 0 до 1000 дробных чисел 0<=n<=1. Выведите n+1 число: вероятность выпадения ровно 0 орлов, 1 орла... n орлов.
Пример ввода:
0.4 1 0.5
Пример вывода:
0.0 0.3 0.5 0.2


Уже несколько недель бьюсь над задачей, математически все понятно, а реализовать на python не получается.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.10.2021, 21:49
Ответы с готовыми решениями:

Задача на теорию вероятности в Python
Всем здравствуйте! Вот дана такая задача: Дано: количество человек в группе. Найти количество парней в группе при условии, что...

Задача на теорию вероятностей
Здравствуйте, помогите, пожалуйста, с решением задачи &quot;Чёрные и белые&quot;. Рассмотрим игру. В ряд лежат n шариков двух цветов: черные и...

2 задача на теорию вероятностей
При стрельбе отклонение от цели в среднем равно нулю. Известно, что с вероятностью 0,95 отклонение по модулю не превосходит 5 см. Найти...

11
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
12.10.2021, 22:38
Ну давай покажи математическое решение
1
0 / 0 / 0
Регистрация: 23.09.2021
Сообщений: 4
12.10.2021, 23:09  [ТС]
Ну допустим нужно найти вероятность выпадения ровно 0 орлов, перемножаем вероятности (1-p(i))
0.6*0*0.5 = 0
Вероятность выпадения ровно двух орлов, просчитываем все комбинации при которых это случится:
0.6*1*0.5 + 0.4*1*0.5 = 0.5
И так по аналогии с любым числом успехов, а вот как реализовать это через циклы не пойму, надо как-то заменять вероятность, на обратную вероятность в массиве нужное колличество раз и делать это всеми возможными способами, а потом каждый раз перемножать элементы.
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
13.10.2021, 09:11
ну а формула какая? что такое число сочетаний?
0
0 / 0 / 0
Регистрация: 23.09.2021
Сообщений: 4
13.10.2021, 11:19  [ТС]
Формула C(k, n) = n! / (k! (n-k)!)
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
13.10.2021, 12:27
вроде так
https://www.cyberforum.ru/cgi-bin/latex.cgi?{C}^{i}_{n}\cdot {p}^{i}\cdot {(1-p)}^{n-i} вероятность выпадение i орлов
0
0 / 0 / 0
Регистрация: 23.09.2021
Сообщений: 4
13.10.2021, 13:16  [ТС]
Если бы) Эта формула подходит когда каждый раз одна и та же вероятность выпадения орла, а у нас в задаче она каждый раз разная.
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
13.10.2021, 18:47
ну почти тоже самое только вместо p берешь pi в комбинации с сочетаниями


C(3,0)
0 0 0 - (1-p0)*(1-p1)*(1-p2) = (1-0.4) * (1-1) * (1-0.5) = 0.0
итого сумма: 0.0

C(3,1)
0 0 1 - (1-p0) * (1-p1) * p2 = (1-0.4) * (1-1) * 0.5 = 0
0 1 0 - (1-p0) * p1 * (1-p2) = (1-0.4) * 1 *(1-0.5) = 0.3
1 0 0 - p1 * (1-p1) * (1-p2) = 0.4 * (1-1) * (1-0.5) = 0
итого сумма: 0.3

C(3,2)
0 1 1 - (1-p0) * p1 * p2 = (1-0.4) * 1 * 0.5 = 0.3
1 0 1 - p0 * (1-p1) * p2 = 0.4 * (1-1) * 0.5 = 0.0
1 1 0 - p0 * p1 * (1-p2) = 0.4 * 1 * (1-0.5) = 0.2
итого сумма: 0.5

C(3,3)
1 1 1 - p0*p1*p2 = 0.4 * 1 * 0.5 = 0.2
итого сумма: 0.2
0
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
13.10.2021, 23:06
Эмин01, Собрал "на скорую руку". Уверен, что можно "причесать", но в принципе работает.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import itertools
from functools import reduce
 
p = [0.4, 1.0, 0.5]
 
q = [1 - i for i in p]
print(reduce(lambda a, b: a * b, q))
 
a = range(len(p))
 
for i in range(1, len(p)):
    c = list(itertools.combinations(a, i))
    s = []
    for j in c:
        t = p[:]
        for k in j:
            t[k] = 1 - t[k]
        t = [1 - i for i in t]
        s.append(reduce(lambda a, b: a * b, t))
    print(sum(s))
 
print(reduce(lambda a, b: a * b, p))
Добавлено через 6 минут
Укоротил на одну строчку.
Кликните здесь для просмотра всего текста
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
import itertools
from functools import reduce
 
p = [0.4, 1.0, 0.5]
 
q = [1 - i for i in p]
print(reduce(lambda a, b: a * b, q))
 
a = range(len(p))
 
for i in range(1, len(p)):
    c = list(itertools.combinations(a, i))
    s = []
    for j in c:
        t = q[:]
        for k in j:
            t[k] = 1 - t[k]
        s.append(reduce(lambda a, b: a * b, t))
    print(sum(s))
 
print(reduce(lambda a, b: a * b, p))


Добавлено через 5 минут
Еще три выпилил.
Кликните здесь для просмотра всего текста
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import itertools
from functools import reduce
 
p = [0.4, 1.0, 0.5]
 
q = [1 - i for i in p]
print(reduce(lambda a, b: a * b, q))
 
a = range(len(p))
 
for i in range(1, len(p)):
    c = list(itertools.combinations(a, i))
    s = []
    for j in c:
        t = [1 - q[k] if k in j else q[k] for k in a]
        s.append(reduce(lambda a, b: a * b, t))
    print(sum(s))
 
print(reduce(lambda a, b: a * b, p))
1
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
14.10.2021, 06:52
anton78spb, было бы что там выпиливать.

Python
1
2
3
4
5
from itertools import combinations as cmb
from functools import reduce
p = [0.4, 1.0, 0.5]
print(*[sum(reduce(lambda a, b: a * b, [p[k] if k in j else 1-p[k] for k in range(len(p))])
            for j in cmb(range(len(p)), i)) for i in range(0, len(p)+1)], sep='\n')
вообще она без itertools нормально решается.
3
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
14.10.2021, 09:02
eaa, Спасибо что "прочесали". Сам понимал, что можно это все свернуть до одной-двух строк, но вчера на ночь глядя лень уже было, да и голова уже думать отказывались.

Добавлено через 10 минут
Там чтобы ещё укоротить можно functools reduce с lambda на math prod заменить.
Python
1
2
3
4
5
from itertools import combinations as cmb
from math import prod
p = [0.4, 1.0, 0.5]
print(*[sum(prod([p[k] if k in j else 1-p[k] for k in range(len(p))])
            for j in cmb(range(len(p)), i)) for i in range(0, len(p)+1)], sep='\n')
3
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
14.10.2021, 10:03
тут главное формулу понять.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.10.2021, 10:03
Помогаю со студенческими работами здесь

Задача на теорию вероятностей
в группе 15 свидетелей, 10 из которых не лгут. На удачу было отобрано 5 свидетелей. Найдите вероятность того,что среди выбранных не лгут...

3 задача на теорию вероятностей
Задана функция распределения случайно величины X: 0, x ≤ -a; F(x) = *знак системы* A +...

Задача на программирование и теорию вероятностей
Требуется написать фрагмент тела функции, который присваивает переменным a, b и c такие случайные целые значения, которые удовлетворяют...

Задача на теорию
Всем доброго времени суток. Классификация шифров замены по мощности алфавита, какой класс надёжней и почему? Доказать на графиках используя...

Задача на теорию автоматов
Условие во вложение. Не совсем понимаю алгоритм. Есть какие-нибудь идеи?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru