Задачу проще всего решить, уже имея набор этих чисел, а их не так много и их можно найти в интернете)
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector <long long int> armstrong = {1, 2, 3, 4, 5, 6, 7, 8, 9, 153, 370, 371, 407, 1634, 8208, 9474, 54748, 92727, 93084, 548834, 1741725, 4210818, 9800817, 9926315, 24678050, 24678051, 88593477, 146511208, 472335975, 534494836, 912985153, 4679307774};
long long int n;
int l = armstrong.size();
cin >> n;
for (int i = 0; i < l && armstrong[i] <= n; ++i)
cout << armstrong[i] << '\n';
return 0;
}
Var
a: array[1..50] of integer;
max, maxi: integer;
begin
Randomize;
for var i := 1 to 50 do a[i] := Random(1, 1000);
writeln(a);
max := a[1];
maxi := 1;
for var i := 1 to 50 do
if a[i] > max then begin
max := a[i];
maxi := i;
end;
a[maxi] := 0;
writeln('Максимальный был на ', maxi, ' месте и равнялся ', max);
writeln(a);
<span>end.</span>
1/8 кб = 1024 бита
1024 / 256 = 4 бита весит 1 символ
2^4 = 16 символов
1. I₁ = K₁ * log₂(i₁) = 20 * log₂(512) = 20 * 9 = 180 бит
I₂ = K₂ * log₂(i₂) = 40 * log₂(32) = 40 * 5 = 200 бит
I₁ < I₂
2. Здесь не дан тип кодировки символов. Недостаточное условие. Возможно, "созданная с помощью ПК" что-то значит, уточните, пожалуйста, если хотите видеть решение.
3. ΔI = I₁ - I₂ = 3 Мбайт - 400 байт = 3 * 2²³ - 400 * 2³ = 3 * 2²³ - 5² * 2⁴ = 2⁴(3 * 2¹⁹ - 5²) = 2⁴(1572864 - 25) = 16 * 1572839 = 25165424 бит