Дан двумерный массив целых чисел. Вставить в него: а) строку из нулей перед всеми строками, в которых количество положительных элементов равно количеству отрицательных;
б) столбец из чисел 10 перед всеми столбцами, в которых количество положительных элементов больше количества отрицательных.
программа выводит только количество положительных и отрицательных элементов на каждой строке.
#include
#include
#include
#include
using namespace std;
int main() {
srand((int) time(0));
int N, M, count = 0;
cout << "N=";
cin >> N;
cout << "M=";
cin >> M;
double **a = new double *[N];
for (int i = 0; i < N; i++)
a[i] = new double[M];
for (int i = 0; i < N; i++) {
count = 0;
for (int j = 0; j < M; j++) {
a[i][j] = rand() % 19 - 9;
if (a[i][j] < 0.) count++;
cout << setw(2) << a[i][j] << " ";
}
cout << " negative: " << count << "\n";
}
for (int i = 0; i < N; i++) {
count = 0;
for (int j = 0; j < M; j++) {
if (a[i][j] > 0.) count++;
}
cout << " positive: " << count << "\n";
}
return 0;
}
1) 1
2) 2
3) 2
4) 2
Объяснение:
1)
т.к. выражение в информатике - запись про которую можно однозначно сказать, оно ложно или нет
2)
а) НЕ (Первая буква согласная) - Первая буква гласная
б) НЕ (Последняя буква гласная) - Последняя буква согласная
ИЛИ - Одно из двух условий
ложно для имени - ни условие а), ни условие б) не выполняется
Пимен выполняет условие б)
Кристина не выполняет ни одно из условий
Ирина выполняет условие а)
Александр выполняет условие а)
3)
¬ - оператор НЕ
& - оператор И
В общем виде НЕ(условие 1) И НЕ(условие 2)
Выражение истинно если не выполняются оба условия
Условие 1: x < 6.
Условие 2: x < 7.
Искомое число больше чем 6 и 7. Минимальное целое - 8.
Из предложенных вариантов подходит только 9
** (* - любой из символов В или С)
*А*
ААА*АА*
АА*ААА*
А**
** (пока 6 вариантов)
Далее - аналогично:
**А
ААА*А*А
АА*АА*А
А*ААА*А
**А (ещё 5 вариантов)
ААА**АА
АА*А*АА
А*АА*АА
*ААА*АА (ещё 4 варианта)
АА**ААА
А*А*ААА
*АА*ААА (ещё 3 варианта)
А**
*А* (ещё 2)
** (ещё 1)
Итого: 6+5+4+3+2+1=21
Так как на месте * могут быть любые из 2 символов В или С, то это даст ещё по 4 варианта для каждого случая.
Можно здесь, конечно, комбинаторику вспомнить.
Итого: 21*4 = 84