#include <iostream>
using namespace std;
int main()
{
int m, n;
cin >> m >> n; // ввод m и n
int A[m][n];
// ввод элементов матрицы
for(int i = 0; i < m; i++)
for(int j = 0; j < n; j++)
cin >> A[i][j];
// решение
int B[n], t, s;
for(int j = 0; j < n; j++)
{
int i = 1;
for(i = 1, t = 1, s = A[0][j]; i < m; i++)
if(A[i][j] < s)
s = A[i][j];
else
{
t = 0;
break;
}
B[j] = t;
}
// вывод вектора B
cout << endl;
for(int j = 0; j < n; j++)
cout << B[j] << " ";
return 0;
}
Месяц находим методом половинного деления.
Двоичная запись числа 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 апреля.
public static void main(String args[]){
java.util.Scanner in = new java.util.Scanner(System.in);
byte bArray[] = new byte[5];
for(int cByte = 0; cByte<bArray.length; cByte++)bArray[cByte] = in.nextByte();
for(int eByte = 0; eByte<bArray.length; eByte++)
for(int sByte = eByte+1; sByte<bArray.length; sByte++)
if(bArray[eByte]==bArray[sByte]){System.out.print("YES");return;}
System.out.print("NO");
}
}