Поделитесь своими знаниями, ответьте на вопрос:
На вход алгоритма подаётся натуральное число n. алгоритм строит по нему новое число r следующим образом. 1) строится двоичная запись числа n. 2) к этой записи дописывается справа бит чётности: 0, если в двоичном коде числа n было чётное число единиц, и 1, если нечётное. 3) к полученному результату дописывается ещё один бит чётности. полученная таким образом запись (в ней на два разряда больше, чем в записи исходного числа n) является двоичной записью искомого числа r. укажите минимальное число r, большее 121, которое может быть получено в результате работы этого алгоритма. в ответе это число запишите в десятичной системе
ответ:
#include
#include
#include
using namespace std;
int main()
{
int i, j, n, m;
double** a;
double p;
setlocale(lc_all, "russian");
cout < < "\nn = ";
cin > > n;
cout < < "\nm = ";
cin > > m;
a = new double*[n];
for (i = 0; i < n; i++)
a[i] = new double[m];
srand(time(null));
for (i = 0; i < n; i++) {
for (j = 0; j < m; j++) {
a[i][j] = (double)rand() / (rand_max + 1) * 10;
cout < < setw (5) < < fixed < < setprecision (2) < < a[i][j] < < " ";
}
cout < < "\n";
}
cout < < "\nпроизведения строк: ";
for (i = 0; i < n; i++) {
p = 1;
for (j = 0; j < m; j++) {
p *= a[i][j];
}
cout < < setw (15) < < fixed < < setprecision(2) < < right < < "\n" < < p;
}
cout < < "\n";
}