1. Элементами множеств A, P и Q являются натуральные числа, причём P = {2, 4, 6, 8, 10, 12} и Q = {2, 6, 12, 18, 24}. Известно, что выражение (x ∈ Q) --> ((x ∈ A) --> (x ∈ P)) истинно при любом значении переменной x. Определите наименьшее возможное количество элементов множества A.
2. Для какого наименьшего неотрицательного целого десятичного числа A формула x & 25 ≠ 0 --> (x & 17 = 0 --> x & A ≠ 0) тождественно истинна, т.е. принимает значение 1 при любом неотрицательном целом значении десятичной переменной x? (Здесь & - поразрядная конъюнкция двух неотрицательных целых десятичных числе.)
type omas=array[1..n] of integer;
Procedure Del (var z:omas; k:byte);
var i:byte;
begin
for i:=k to n-1 do z[i]:=z[i+1];
z[n]:=0;
end;
var a:omas; i,b:integer;
begin
Randomize;
for i:=1 to n do
begin
a[i]:=random(20);
write(a[i]:4);
end;
writeln;
b:=6;
i:=1;
while (i<=n)and(a[i]<>b) do i:=i+1;
if i<=n then
begin
Del(a,i);
writeln('Размерность массива = ',n-1);
for i:=1 to n-1 do write(a[i]:4);
writeln;
end else writeln('Массив не изменился');
end.
Пример:
12 13 6 7 17 1 18 17 3 2 12 3 16 6 7 13 0 2 5 18
Размерность массива = 19
12 13 7 17 1 18 17 3 2 12 3 16 6 7 13 0 2 5 18
#include <iostream>
#include <string>
#include <cctype>
using namespace std;
signed main() {
string line, buff = "";
bool isPalindrome = true;
getline(cin, line);
for (int i = 0; i < line.size(); i++) {
if (isalnum(line[i]))
buff += line[i];
}
for (int i = 0; i < buff.size() / 2; ++i)
{
if (buff[i] != buff[buff.size() - i - 1])
{
isPalindrome = false;
break;
}
}
if (isPalindrome)
cout << "TRUE";
else
cout << "FALSE";
return 0;
}