Не понимаю, что такое количество вопросов "в битах" !!!
Месяц находим методом половинного деления.
Двоичная запись числа 366 размещается в 9 битах (в 8 битах размещается только 256 чисел, а в 9 битах - уже 512). Следовательно, понадобится задать 8 вопросов и девятой фразой будет ответ.
В году 365 (366) дней. Пусть 366, для 365 рассуждение то же.
Рассмотрим самый худший вариант
Середина года - день номер 366/2=183. Это 1 июля.
Первый вопрос: День рождения в первой половине года?
Допустим, да.
Второй вопрос: День рождения в первом квартале?
Допустим, нет. Следовательно во втором.
Второй квартал - это дни с номерами от 92 до 182. Середина - среднее арифметическое. (92+182)/2=137. Это дата 17 мая.
Третий вопрос: День рождения позднее 17 мая?
Допустим, нет.
Следовательно, интервал дат 1 апреля - 17 мая, 91 день. Опять делим на 2, сужая интервал до 22 дней. Это дата 22 апреля.
Четвертый вопрос: День рождения позднее 22 апреля?
Допустим, нет.
Новый диапазон поиска - 23 апреля - 17 мая. Половиним его.
Пятый вопрос: День рождения позднее 29 апреля?
Допустим, нет.
Поиск сузился до 23 - 29 апреля. Снова берем половину.
Шестой вопрос: День рождения позднее 26 апреля?
Допустим, нет.
Интервал дат 23-26 апреля. Половиним.
Седьмой вопрос: День рождения позднее 24 апреля?
Допустим, да.
Интервал дат 25-26 апреля.
Восьмой вопрос: День рождения 25 апреля?
Допустим, нет
Девятая фраза: Ваш день рождения 26 апреля.
Число
Все 5.
Гномы видели, что существовало всего 3 красных капюшона. А значит те, на кого надеты капюшоны синего цвета сразу могут дать ответ, что на них синие. Если гномы в красных капюшонах видят, что гномы в синих ответили, то понимают, что эти гномы должны быть уверены в правильности их ответа, а значит все оставшиеся - с красными. И поэтому оставшиеся 3 тоже могут ответить правильно.
Var mas: array[1..15] of integer;
i, min, max, nMin, nMax:integer;
begin
writeln('Введите 15 элементов массива');
for i := 1 to 15 do
readln(mas[i]);
min := mas[1];
max := mas[1];
nMin := 1;
nMax := 1;
for i := 1 to 15 do
begin
if max < mas[i] then
begin
max := mas[i];
nMax := i;
end;
if min > mas[i] then
begin
min := mas[i];
nMin := i;
end;
end;
writeln('Максимальное число и его номер ', max, ' ', nMax, ' Минимальное число и его номер ', min, ' ', nMin);
end.
Так.
Вот у нас диаграмма.
Из нее видим, что одна часть составляет половину, одна часть составляет четверть, две части составляют по восьмой части.
При подставлении в формулы получается число, которое должно соответствовать одной из части диаграммы.
и так, поехали искать формулу.
возьмем формулу
(2, b) ( 5 + 3)/2 = 8/2 = 4
(2, c) 5 - 3 = 2
(2, d) 4 / 2 = 2
и так, у нас получились числа 2, 2, 4.
дальше начинаем перебирать формулы, которые в низу которые надо подобрать под ответ:
1) a1 + c1 + d1 = 2 + 5 + 3 = 10, не подходит, потому что должно получиться 8(это следует из того, что у нас уже есть две 2, которые являются восьмыми частями диаграммы и 4, которая является четвертью, значит половина должна быть 8)
2) 2 * d1 = 2* 3 = 6, не подходит
3) a1/2 = 2/2 = 1, не подходит
4) a1 * b1 = 2 * 4 = 8, это выражение нам подходит
у нас получаются числа
2 2 4 8
соответствующая формула для 2А будет под номером 4
№1 var s,x,n,i:integer;begins:=0;write('Введите количество чисел: ');readln(n);writeln('Введите числа: ');for i:=1 to n dobeginreadln (x);s:=s+xend;writeln('Сумма чисел равна ',s);end.
№2 var n,i,p:integer;beginp:=1;write('Введите количество чисел: ');readln(n);for i:=1 to n dop:=p*i;writeln('Произведение чисел равнo ',p);end.
Подробнее - на Znanija.com -
znanija.com/task/14923730#readmore