#include <iostream>
using namespace std;
void swap(int i, int j, int a[])
{
int t = a[i];
a[i] = a[j];
a[j] = t;
}
int main()
int n, s1 = 0, s2 = 0, n1 = 0, n2 = 0;
cin >> n;
int a[n];
srand(time(0)); // инициализируем датчик
// заполняем массив подряд от 1 до n
for(int i=0; i<n; i++)
a[i] = i + 1;
int np = min(rand() % n, 5); // случайное количество перестановок
for(int i=1; i<=np; i++)
swap(rand()%(n), rand()%(n), a);
cout << a[i] << " ";
return 0;
3)не (X и Y) или Z
Объяснение:
1) не (X и Y) и Z
Поскольку тут перед Z стоит операция И, то при Z = 0 всегда будет F = 0, поэтому такая функция исключается.
2) не (X или не Y) или Z
Поскольку тут перед Z стоит операция ИЛИ, то при Z = 1 будет F = 1. Проверим комбинации, где Z = 0.
Для X=0, Y=0 получаем
F = не (0 или не 0)
F = не (0 или 1)
F = не (1)
F = 0
Но в первой строке таблицы стоит 1, поэтому такая функция исключается.
3) не (X и Y) или Z
Здесь по Z рассуждения, как в 2).
F = не (0 и 0)
F = не (0)
F = 1 - первая строка проверку.
Для X=0, Y=1 получаем
F = не (1 и 0)
F = 1 - последняя строка проверку.
Функция подходит.
4) (X или Y) и Z
Рассуждения, как в случае 1), функция не подходит.
#include <iostream>
using namespace std;
void swap(int i, int j, int a[])
{
int t = a[i];
a[i] = a[j];
a[j] = t;
}
int main()
{
int n, s1 = 0, s2 = 0, n1 = 0, n2 = 0;
cin >> n;
int a[n];
srand(time(0)); // инициализируем датчик
// заполняем массив подряд от 1 до n
for(int i=0; i<n; i++)
a[i] = i + 1;
int np = min(rand() % n, 5); // случайное количество перестановок
for(int i=1; i<=np; i++)
swap(rand()%(n), rand()%(n), a);
for(int i=0; i<n; i++)
cout << a[i] << " ";
return 0;
}
3)не (X и Y) или Z
Объяснение:
1) не (X и Y) и Z
Поскольку тут перед Z стоит операция И, то при Z = 0 всегда будет F = 0, поэтому такая функция исключается.
2) не (X или не Y) или Z
Поскольку тут перед Z стоит операция ИЛИ, то при Z = 1 будет F = 1. Проверим комбинации, где Z = 0.
Для X=0, Y=0 получаем
F = не (0 или не 0)
F = не (0 или 1)
F = не (1)
F = 0
Но в первой строке таблицы стоит 1, поэтому такая функция исключается.
3) не (X и Y) или Z
Здесь по Z рассуждения, как в 2).
Для X=0, Y=0 получаем
F = не (0 и 0)
F = не (0)
F = 1 - первая строка проверку.
Для X=0, Y=1 получаем
F = не (1 и 0)
F = не (0)
F = 1 - последняя строка проверку.
Функция подходит.
4) (X или Y) и Z
Рассуждения, как в случае 1), функция не подходит.