1.
for i := 1 to 20 do
writeln(i);
В данном фрагменте никаких ошибок нет, все правила написания кода соблюдены, на экран выведутся числа от 1 до 20(каждое на новой строке)
2.
for i := 2 to 20 do
i := i + 1;
В очень древних реализациях Паскаля такой фрагмент заработает, но если обращаться к более современным версиям, то мы не сможем изменить переменную из заголовка цикла в теле цикла и получим ошибку.
3.
for i := 2 to 20 do
readln(i);
Этот фрагмент тоже даст ошибку, потому что переменная i уже объявлена в заголовке, а в теле цикла мы пытаемся ей задать значение с клавиатуры.
4.
for i := 2 to 20 do
A := i * i;
Этот фрагмент не вызовет ошибок, если переменная "A" у нас будет объявлена, каждый проход цикла мы будем переменной A присваивать значение . По сути, такая реализация не имеет смысла, потому что в конце мы получим просто значение A = , так как каждый проход значение заменяется следующим.
64
Объяснение:
V = K * i, где
V - это информационный объём текстового сообщения (размер файла, содержащего сообщение)
K - количество символов в сообщении
i - информационный вес одного символа (число бит, используемых для записи одного символа)
N = 2^i, где
N - мощность алфавита (количество символов в алфавите)
i - информационный вес одного символа (число бит, используемых для записи одного символа)
^ - знак степени
Дано:
V = 15 Кбайт = 15 * 1024 = 15 360 байт = 15 360 * 8 = 122 880 бит
K = 20 480 символов
Найти:
N
V = K * i
i = V / K
i = 122 880 / 20 480 = 6 бит
N = 2^i
N = 2^6 = 64 символа
Поделитесь своими знаниями, ответьте на вопрос:
Как строиться доменная система имен?