На вход программе подаётся английский текст, заканчивающийся точкой (символ «точка» во входных данных единственный). Текст зашифровать следующим образом: сначала определяется количество букв в самом длинном слове, обозначив полученное число К (словом называется непрерывная последовательность английских букв, слова друг от друга отделяются пробелами и запятыми, длина слова не превышает 20 символов). Затем проводится замена каждой английской буквы на букву, следующую за ней К-ю по счету в алфавите (алфавит считается циклическим, то есть после буквой Z стоит буква А), оставив другие символы неизменными. Строчные буквы при этом остались строчными, а прописные - прописными. Требуется написать программу, которая будет выводить на экран зашифрованный текст и число К.
Заранее
При столбцовой перестановке главное - это угадать количество столбцов. Их может быть от двух до половины символов в тексте. В этом случае полезно начать с выделения слова и решения полученной анаграммы.
Например, анаграмма ИПКСОЕ не дает осмысленного слова а русском языке. Укоротим ее на одну букву. ИПКСО - анаграмма слова ПОИСК. Логично предположить, что количество столбцов равно 5.
31542 - порядок столбцов
ИПКСО
Е_ТСМ
НАЧИ_
ОЕН_Г
ДЕЛА
После перестановки:
ПОИСК
МЕСТ
А НИЧ
ЕГО Н
Е ДАЛ
Результат: "ПОИСК МЕСТА НИЧЕГО НЕ ДАЛ"
Переводим число 54 (отбросив знак) в двоичную систему счисления. Получаем число 110110₂. Допустим, для представления числа отведен один байт, тогда 54₁₀ = 0011 0110₂. Это прямой код числа.
Отрицательное число может быть представлено в обратном или дополнительном коде. В обратном коде старший (левый) разряд отрицательного числа равен единице, а остальные семь разрядов прямого кода инвертируются. Получаем 1100 1001₂ В дополнительном коде еще нужно арифметически прибавить единицу. Получим 1100 1010₂
Запись в естественной форме:
10.00761 • 10⁶ = 10007610
3218.9 • 10⁻³ = 3.2189
23,66100Е+3 = 23661