я просто ищу все простые числа в диапазоне от 1 до n с решето эратосфена, а далее просто сравниваю вектор с простыми числами.
#include
using namespace std;
int main()
{
int n;
cin > > n;
vector prime (n+1, true);
prime[0] = prime[1] = false;
for (int i=2; i*i< =n; ++i)
if (prime[i])
for (int j=2; j< =n/i; j++)
if (prime[i*j]) prime[i*j] = false;
for(int i = 0; i < prime.size(); ++i)
for(int j = i; j < prime.size(); ++j)
if(prime[i]& & prime[j])
if(i+j==n)
cout < < i < < " " < < j < < endl;
}
cin.get();
Не очень понятно, длину двоичного кода одного символа или длину двоичного кода всех 33 символов, как бы записанных в ряд..
Ну да ладно, вычислим, сколько информации содержит 1 символ при мощности алфавита = 33:
33 = 2ˣ => минимальный x = 6
Значит один символ будет нести 6 бит информации, то есть длина двоичного кода для записи одного символа равна 6.
Если мы умножим 6 на количество символов, то получим количество информации, требуемое для записи 33 букв, т.е.:
6*33 = 198 бит
ответ: Длина двоичного кода одной буквы равна 6, а 33 букв - 198.
я просто ищу все простые числа в диапазоне от 1 до n с решето эратосфена, а далее просто сравниваю вектор с простыми числами.
мой пример решения:#include
#include
using namespace std;
int main()
{
int n;
cin > > n;
vector prime (n+1, true);
prime[0] = prime[1] = false;
for (int i=2; i*i< =n; ++i)
if (prime[i])
for (int j=2; j< =n/i; j++)
if (prime[i*j]) prime[i*j] = false;
for(int i = 0; i < prime.size(); ++i)
{
for(int j = i; j < prime.size(); ++j)
{
if(prime[i]& & prime[j])
if(i+j==n)
cout < < i < < " " < < j < < endl;
}
}
cin.get();
cin.get();
}
Не очень понятно, длину двоичного кода одного символа или длину двоичного кода всех 33 символов, как бы записанных в ряд..
Ну да ладно, вычислим, сколько информации содержит 1 символ при мощности алфавита = 33:
33 = 2ˣ => минимальный x = 6
Значит один символ будет нести 6 бит информации, то есть длина двоичного кода для записи одного символа равна 6.
Если мы умножим 6 на количество символов, то получим количество информации, требуемое для записи 33 букв, т.е.:
6*33 = 198 бит
ответ: Длина двоичного кода одной буквы равна 6, а 33 букв - 198.