На листе бумаги записали числа от 0 до 9. Не глядя выбирают два числа и находят их сумму. Являются ли события: сумма этих чисел равна 1 и сумма этих чисел равна 9, равновероятными? Если нет, то какое событие более вероятно? Почему большое!
В цикле с условием while цикл выполняется, пока истинно задающее его условие. Поэтому этот цикл также иногда называют циклом "пока". Часто цикл while используется, когда невозможно заранее предсказать, сколько раз необходимо выполнить тело цикла. В повседневной жизни цикл while можно встретить в алгоритмах, вроде "Пока в пределах видимости есть машины, стоять на месте" или "Пока в ящике есть детали, достать деталь из ящика".
В следующей программе цикл while используется подобно циклу for для вывода на экран всех чисел от 1 до 10:
i=1
while i<=10:
print i
i=i+1
В этой программе переменной i присваивается значение 1. Затем начинается цикл (ключевое слово while) с проверяемым условием i<=10. Тело цикла содержит две инструкции: вывод на экран значения переменной i и увеличение значения переменной i на 1.
При выполнении этого цикла проверяется условие i<=10. Поскольку значение i изначально равно 1, то условие верно и выполняется тело цикла: на экран выводится значение переменной i, то есть 1 и переменной i присваивается значение i+1, то есть 2. Снова проверяется условие, поскольку оно верно, то выполняется блок цикла: на экран выводится число 2 и переменной i присваивается значение 3. Опять проверяется значение цикла, и так далее до тех пор, пока проверяемое условие истинно.
Как только проверяемое условие станет ложно (это произойдет, когда переменная i станет равна 11), цикл завершит работу и управление будет передано следующей инструкции после блока цикла. Поэтому после завершения цикла переменная i будет иметь значение 11.
В общем виде синтаксис цикла с условием в языке Питон такой:
while условие:
инструкция 1
инструкция 2
...
инструкция n
В каждой инструкции while должны присутствовать:
Условие, определяющее, будет ли выполняться тело цикла. Это условие записывается после слова while и может быть произвольным арифметическим выражением, в котором должен быть хотя бы один из операторов ==, !=, <, >, <=, >= и могут использоваться логические операторы and, or, not. После условия ставится двоеточие.
Тело цикла, состоящее из одной или нескольких инструкций, записанных с отступом одинаковой величины.
Инструкции, изменяющие значения переменных, входящих в проверяемое условие. В рассмотренном примере это инструкция i=i+1. Если бы этой инструкции не было, то значение переменной i не менялось бы и проверяемое условие всегда было бы истинным, что привело бы к бесконечному циклу. Для прерывания работы программы, попавшей в бесконечный цикл, используется комбинация клавиш Ctrl+C.
Цикл while в Питоне всегда можно использовать вместо цикла for. Однако иногда цикл for удобней, а иногда удобней цикл while, как в следующем примере, где вычисляется наименьшая степень двойки, которая превосходит данное число n:
n=input("Введите натуральное число")
i=0
while 2**i<=n:
i=i+1
print "2 в степени",i,"превосходит данное число"
В этом примере переменная i внутри цикла увеличивается на 1, пока значение 2**i не превосходит n. После окончания цикла величина 2**i будет больше n, и соответствующее значение i будет напечатано на экране.
Внутри цикла могут быть различные другие инструкции, в том числе инструкции if, while и for. В этом случае говорят о вложенных циклах, или об условной инструкции, вложенной в цикл. Тело вложенного цикла выделяется от цикла, в который оно вложено, большей величиной отступа.
Рассмотрим два примера. В первом примере программа печатает на экран все натуральные делители данного натурального числа n. Для этого используется цикл, в котором переменная i меняется от 1 до n, а внутри цикла проверяется условие, и если остаток от деления n на i равен 0, то печатается значение i:
n=input("Введите число, для которого необходимо вывести делители")
i=1
while i<=n:
if n%i==0:
print i
i=i+1
В следующем примере на экран печатается таблица умножения всех однозначных чисел. Для этого организовано два цикла: в одном переменная i меняется от 1 до 9, внутри этого цикла (то есть при каждом новом значении i) переменная j также меняется от 1 до 9. В блоке вложенного цикла на экран печатаются значения переменных i, j и их произведение:
i=1
while i<10: # Условие внешнего цикла по i
j=1
while j<10: # Условие внутреннего цикла по j
print i, "*", j, "=", i*j
j=j+1 # Инструкция-итератор вложенного цикла
i=i+1 # Инструкция-итератор внешнего цикла
С использованием циклов for этот пример можно записать короче:
обоснование числовой лотереи рассчитывается с применением теории вероятностей и теории чисел. рассчитав вероятное число выигрышей каждого класса, можно узнать, какой процент от общей суммы доходов должен пойти на выигрыши каждого класса и какова должна быть сумма каждого выигрыша.
общее количество комбинаций в числовой лотерее рассчитывается при формулы: “а номеров из n” = (n)
(a) = n x (n - 1) x (n - 2) x (n - 3) … x [n - (a -1)]
1 x 2 x 3 x 4 x a
в числовой лотерее “6 из 49” общее количество комбинаций составляет: “6 из 49” = (49)
(6) = 49 x 48 x 47 x 46 x 45 x 44
1 x 2 x 3 x 4 x 5 x 6 = 13 983 816 комбинаций
вероятное число выигрышей каждого класса определяется с учетом коэффициента вероятности каждого выигрыша следующим образом:
выигрыши 1 класса (за 6 угаданных номеров) :
(6)
(6) х (43)
( 0 ) = 6 х 5 х 4 х 3 х 2 х 1
1 х 2 х 3 х 4 х 5 х 6 = 1 выигрыш
выигрыши 2 класса (за 5 угаданных номеров) :
(6)
(5) х (43)
( 1 ) = 6 х 5 х 4 х 3 х 2
1 х 2 х 3 х 4 х 5 x 43
1 = 258 выигрышей
выигрыши 3 класса (за 4 угаданных номера) :
(6)
(4) х (43)
( 2 ) = 6 х 5 х 4 х 3
1 х 2 х 3 х 4 x 43 х 42
1 х 2 = 27 090 выигрышей
всего в лотерее “6 из 49”, таким образом, содержится 27 349 выигрышей, т. е. 1 выигрыш приходится на 511 комбинаций.
вероятность появления выигрыша каждого класса определяется отношением вероятного числа выигрышей к общему числу случаев выигрышей, равному общему количеству комбинаций в лотерее:
В цикле с условием while цикл выполняется, пока истинно задающее его условие. Поэтому этот цикл также иногда называют циклом "пока". Часто цикл while используется, когда невозможно заранее предсказать, сколько раз необходимо выполнить тело цикла. В повседневной жизни цикл while можно встретить в алгоритмах, вроде "Пока в пределах видимости есть машины, стоять на месте" или "Пока в ящике есть детали, достать деталь из ящика".
В следующей программе цикл while используется подобно циклу for для вывода на экран всех чисел от 1 до 10:
i=1
while i<=10:
print i
i=i+1
В этой программе переменной i присваивается значение 1. Затем начинается цикл (ключевое слово while) с проверяемым условием i<=10. Тело цикла содержит две инструкции: вывод на экран значения переменной i и увеличение значения переменной i на 1.
При выполнении этого цикла проверяется условие i<=10. Поскольку значение i изначально равно 1, то условие верно и выполняется тело цикла: на экран выводится значение переменной i, то есть 1 и переменной i присваивается значение i+1, то есть 2. Снова проверяется условие, поскольку оно верно, то выполняется блок цикла: на экран выводится число 2 и переменной i присваивается значение 3. Опять проверяется значение цикла, и так далее до тех пор, пока проверяемое условие истинно.
Как только проверяемое условие станет ложно (это произойдет, когда переменная i станет равна 11), цикл завершит работу и управление будет передано следующей инструкции после блока цикла. Поэтому после завершения цикла переменная i будет иметь значение 11.
В общем виде синтаксис цикла с условием в языке Питон такой:
while условие:
инструкция 1
инструкция 2
...
инструкция n
В каждой инструкции while должны присутствовать:
Условие, определяющее, будет ли выполняться тело цикла. Это условие записывается после слова while и может быть произвольным арифметическим выражением, в котором должен быть хотя бы один из операторов ==, !=, <, >, <=, >= и могут использоваться логические операторы and, or, not. После условия ставится двоеточие.
Тело цикла, состоящее из одной или нескольких инструкций, записанных с отступом одинаковой величины.
Инструкции, изменяющие значения переменных, входящих в проверяемое условие. В рассмотренном примере это инструкция i=i+1. Если бы этой инструкции не было, то значение переменной i не менялось бы и проверяемое условие всегда было бы истинным, что привело бы к бесконечному циклу. Для прерывания работы программы, попавшей в бесконечный цикл, используется комбинация клавиш Ctrl+C.
Цикл while в Питоне всегда можно использовать вместо цикла for. Однако иногда цикл for удобней, а иногда удобней цикл while, как в следующем примере, где вычисляется наименьшая степень двойки, которая превосходит данное число n:
n=input("Введите натуральное число")
i=0
while 2**i<=n:
i=i+1
print "2 в степени",i,"превосходит данное число"
В этом примере переменная i внутри цикла увеличивается на 1, пока значение 2**i не превосходит n. После окончания цикла величина 2**i будет больше n, и соответствующее значение i будет напечатано на экране.
Внутри цикла могут быть различные другие инструкции, в том числе инструкции if, while и for. В этом случае говорят о вложенных циклах, или об условной инструкции, вложенной в цикл. Тело вложенного цикла выделяется от цикла, в который оно вложено, большей величиной отступа.
Рассмотрим два примера. В первом примере программа печатает на экран все натуральные делители данного натурального числа n. Для этого используется цикл, в котором переменная i меняется от 1 до n, а внутри цикла проверяется условие, и если остаток от деления n на i равен 0, то печатается значение i:
n=input("Введите число, для которого необходимо вывести делители")
i=1
while i<=n:
if n%i==0:
print i
i=i+1
В следующем примере на экран печатается таблица умножения всех однозначных чисел. Для этого организовано два цикла: в одном переменная i меняется от 1 до 9, внутри этого цикла (то есть при каждом новом значении i) переменная j также меняется от 1 до 9. В блоке вложенного цикла на экран печатаются значения переменных i, j и их произведение:
i=1
while i<10: # Условие внешнего цикла по i
j=1
while j<10: # Условие внутреннего цикла по j
print i, "*", j, "=", i*j
j=j+1 # Инструкция-итератор вложенного цикла
i=i+1 # Инструкция-итератор внешнего цикла
С использованием циклов for этот пример можно записать короче:
for i in range(1,10):
for j in range(1,10):
print i, "*", j, "=", i*j
ответ:
обоснование числовой лотереи рассчитывается с применением теории вероятностей и теории чисел. рассчитав вероятное число выигрышей каждого класса, можно узнать, какой процент от общей суммы доходов должен пойти на выигрыши каждого класса и какова должна быть сумма каждого выигрыша.
общее количество комбинаций в числовой лотерее рассчитывается при формулы: “а номеров из n” = (n)
(a) = n x (n - 1) x (n - 2) x (n - 3) … x [n - (a -1)]
1 x 2 x 3 x 4 x a
в числовой лотерее “6 из 49” общее количество комбинаций составляет: “6 из 49” = (49)
(6) = 49 x 48 x 47 x 46 x 45 x 44
1 x 2 x 3 x 4 x 5 x 6 = 13 983 816 комбинаций
вероятное число выигрышей каждого класса определяется с учетом коэффициента вероятности каждого выигрыша следующим образом:
выигрыши 1 класса (за 6 угаданных номеров) :
(6)
(6) х (43)
( 0 ) = 6 х 5 х 4 х 3 х 2 х 1
1 х 2 х 3 х 4 х 5 х 6 = 1 выигрыш
выигрыши 2 класса (за 5 угаданных номеров) :
(6)
(5) х (43)
( 1 ) = 6 х 5 х 4 х 3 х 2
1 х 2 х 3 х 4 х 5 x 43
1 = 258 выигрышей
выигрыши 3 класса (за 4 угаданных номера) :
(6)
(4) х (43)
( 2 ) = 6 х 5 х 4 х 3
1 х 2 х 3 х 4 x 43 х 42
1 х 2 = 27 090 выигрышей
всего в лотерее “6 из 49”, таким образом, содержится 27 349 выигрышей, т. е. 1 выигрыш приходится на 511 комбинаций.
вероятность появления выигрыша каждого класса определяется отношением вероятного числа выигрышей к общему числу случаев выигрышей, равному общему количеству комбинаций в лотерее:
выигрыш 1 класса (за 6 угаданных номеров) :
= 13 983 816
1 = 1 на 13 983 816 комбинаций
выигрыш 2 класса (за 5 угаданных номеров) :
= 13 983 816
258 = 1 на 54 200 комбинаций
выигрыш 3 класса (за 4 угаданных номера) :
= 13 983 816
27 090 = 1 на 516 комбинаций
пошаговое объяснение: