Месяц находим методом половинного деления.
Двоичная запись числа 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 апреля.
#include <cstdlib>
using namespace std;
int main() {
int i,j;
int a[4][3];
for (i=0; i<4; i++){
cout<<"Stroka "<<i+1<<endl;
for (j=0; j<3; j++) {
cout<<"Element "<<j+1<<": ";
cin>>a[i][j];
}
cout<<endl;
}
cout<<"Resul'tat"<<endl;
for (i=0; i<4; i++) {
for (j=0; j<3; j++) {
a[i][j]*=a[i][j];
cout<<a[i][j]<<" ";
}
cout<<endl;
}
cin>>i; //ïðîñòî ÷òîáû ýêðàí íå çàêðûëñÿ
return 0;
}
Тестовое решение (Dev C++)
Stroka 1
Element 1: 1
Element 2: 2
Element 3: 3
Stroka 2
Element 1: 4
Element 2: 5
Element 3: 6
Stroka 3
Element 1: 7
Element 2: 8
Element 3: 9
Stroka 4
Element 1: 10
Element 2: 11
Element 3: 12
Resul'tat
1 4 9
16 25 36
49 64 81
100 121 144: