Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.58/40: Рейтинг темы: голосов - 40, средняя оценка - 4.58
0 / 0 / 0
Регистрация: 09.10.2016
Сообщений: 45

Шифр Юлия Цезаря

27.12.2016, 03:37. Показов 7668. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Юлий Цезарь использовал свой способ шифрования текста. Каждая буква заменялась на следующую по алфавиту через K позиций по кругу. Необходимо по заданной шифровке определить исходный текст.

Входные данные
В первой строке дана шифровка, состоящая из заглавных латинских букв. Во второй строке число K (1 ≤ K ≤ 10).

Выходные данные
Требуется вывести результат расшифровки.

Примеры
входные данные
XPSE
1
выходные данные
WORD
входные данные
ZABC
3
выходные данные
WXYZ

Мой код:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import java.util.Scanner;
 
public class ChiefClass
{
    public static void main(String[] args)
    {
        Scanner in=new Scanner(System.in);
        String s = in.nextLine();
        int a=in.nextInt();
        char []m={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
        char [] chArray=s.toCharArray();
        for (int j=0; j<m.length;j++)
        {
            for (int i = 0; i <chArray.length; i++)
            {
                if (chArray[i]==m[j])
                {
                    if (m[j]=='z')
                    {
                        chArray[i]=m[a];
                    }
                    else
                       chArray[i]=m[j+a];
                }
            }
        }
        System.out.println(s);
    }
}
Понимаю, что ошибка вылезает из-за выхода за пределы массива, но никак не могу понять, как исправить, помогите. пожалуйста
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.12.2016, 03:37
Ответы с готовыми решениями:

Шифр Юлия
Юлий Цезарь использовал свой способ шифрования текста. Каждая буква заменялась на следующую по алфавиту через K позиций по кругу....

Шифр цезаря
Здравствуйте, имеется проблема с созданием приложения , которое могло бы шифровать и расшифровывать текст (для шифрования используется шифр...

Шифр Цезаря
Доброго времени суток. Собственно, из названия ясно, помощь с каким вопросом мне не помешала бы) Задание таково: Написать программу,...

2
3 / 3 / 2
Регистрация: 21.12.2016
Сообщений: 8
27.12.2016, 10:32
Ты циклы перепутал местами.

Для каждой буквы в слове находишь ее индекс в алфавите.
Если кодируешь - увеличиваешь индекс на a, если декодирование - уменьшаешь.
Если индекс вышел за пределы алфавита - корректируешь: если меньше нуля - прибавляешь к индексу размер алфавита, если больше размера алфавита - отнимаешь от индекса размер алфавита.
Если смещение больше, чем размер алфавита - либо кидаешь исключение, либо меняешь if на while в проверке границ алфавита - тогда будет корректировать до тех пор, пока индекс не попадет в алфавит.
После коррекции заменяешь букву на ту, на которую указывает индекс, и переходишь к следующей букве в слове.
И так до тех пор пока буквы в слове не кончатся.
1
Эксперт Java
378 / 370 / 114
Регистрация: 30.06.2010
Сообщений: 1,445
27.12.2016, 11:06
Цитата Сообщение от Yagodniy_Mors Посмотреть сообщение
Java
1
chArray[i]=m[j+a]
индекс массива сам по кругу не ходит.

Java
1
chArray[i]=m[(j+a) % m.length]
Добавлено через 29 минут
а вообще вариант раз:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
        Scanner in = new Scanner(System.in);
        System.out.println("Введите строку");
        String s = in.nextLine();
        System.out.println("Введите смещение");
        int a = in.nextInt();
        System.out.println("введите направление: прямое(+) или обратное(-)");
        int direction = in.nextLine().equals("+") ? 1 : -1;
        List<Character> m = Arrays.asList('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z');
        char[] chArray = s.toCharArray();
        for (int i = 0; i < chArray.length; i++) {
            char c = chArray[i];
            boolean isLower = Character.isLowerCase(c);
            if (!isLower) {
                c = Character.toLowerCase(c);
            }
            int index = m.indexOf(c);
            int position = index + direction * a;
            if (position < 0) {
                position += m.size();
            } else if (position > m.size()) {
                position -= m.size();
            }
            c = m.get(position);
            if (!isLower) {
                c = Character.toUpperCase(c);
            }
            chArray[i] = c;
        }
        System.out.println(chArray);
и два:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
        Scanner in = new Scanner(System.in);
        System.out.println("Введите строку");
        String s = in.nextLine();
        System.out.println("Введите смещение");
        int a = in.nextInt();
        System.out.println("введите направление: прямое(+) или обратное(-)");
        int direction = in.nextLine().equals("+") ? 1 : -1;
        List<Character> m = Arrays.asList('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z');
        char[] chArray = s.toCharArray();
        for (int i = 0; i < chArray.length; i++) {
            char c = chArray[i];
            boolean isLower = Character.isLowerCase(c);
            if (!isLower) {
                c = Character.toLowerCase(c);
            }
            c = m.get((m.indexOf(c) + m.size() + direction * a) % m.size());
            if (!isLower) {
                c = Character.toUpperCase(c);
            }
            chArray[i] = c;
        }
        System.out.println(chArray);
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.12.2016, 11:06
Помогаю со студенческими работами здесь

Шифр Цезаря
Помогите, пожалуйста, решить задачу, а то у меня зачет, а я не знаю как решать В шифре Цезаря каждый символ заменяется на другой...

шифр цезаря
помогите пожалуйста не воспринимает пробел,как исправить? пример Шифр Цезаря Please enter the word to cipher: JAck King ...

Шифр Цезаря
Помогите пожалуйста с задачей Шифр Цезаря В шифре Цезаря каждый символ заменяется на другой символ, третий по счету в алфавите после...

Шифр Цезаря
Привет,народ!Срочно нужен код реализации шифра цезаря на Java,дешифровщик не обязателен,но программу хотелось бы видеть в одном...

Шифр цезаря
Никак не могу понять в чем проблема, может кто подсказать? Стараюсь реализовать шифр цезаря. В этом коде рассматриваю пока только...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru