Форум программистов, компьютерный форум, киберфорум
mutagen
Войти
Регистрация
Восстановить пароль
все вопросы по Java которые задают более 3х раз на форуме
Оценить эту запись

Циклический сдвиг

Запись от mutagen размещена 16.11.2013 в 13:55. Обновил(-а) mutagen 16.11.2013 в 13:57
Показов 4772 Комментарии 2

Любителям шифров начального уровня посвящается )

Максимально шустрый средствами java циклический сдвиг на женериках

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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
import java.util.Arrays;
 
/**
 * @author mutagen
 */
public class CyclicShift<E> {
 
    public E[] shiftLeft(E[] arr) {
        E tmp = arr[arr.length - 1];
        System.arraycopy(arr, 0, arr, 1, arr.length - 1);
        arr[0] = tmp;
        return arr;
    }
 
    public E[] shiftRight(E[] arr) {
        E tmp = arr[0];
        System.arraycopy(arr, 1, arr, 0, arr.length - 1);
        arr[arr.length - 1] = tmp;
        return arr;
    }
 
    public E[] shiftLeft(E[] arr, int count) {
        for (int i = 0; i < count; i++) {
            shiftLeft(arr);
        }
        return arr;
    }
 
    public E[] shiftRight(E[] arr, int count) {
        for (int i = 0; i < count; i++) {
            shiftRight(arr);
        }
        return arr;
    }
 
    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) {
        CyclicShift<Integer> shifter = new CyclicShift<>();
        Integer[] arr = {1, 2, 3, 4, 5, 6};
        System.out.println(Arrays.toString(shifter.shiftLeft(arr)));
        System.out.println(Arrays.toString(shifter.shiftRight(arr, 2)));
        System.out.println(Arrays.toString(shifter.shiftLeft(arr, 2)));
        System.out.println(Arrays.toString(shifter.shiftRight(arr)));
    }
 
}


PS: можно конечно заморочиться и в методах shiftRight(E[] arr, int count) и shiftLeft(E[] arr, int count) тоже сделать через систем-арейкопи, и это будет ещё быстрее, но это уже домашка
Размещено в Без категории
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 2
Комментарии
  1. Старый комментарий
    а нафига нам объект сдвига?
    Запись от Jupiter размещена 16.11.2013 в 14:28 Jupiter вне форума
  2. Старый комментарий
    Аватар для mutagen
    Цитата:
    Сообщение от Jupiter Просмотреть комментарий
    а нафига нам объект сдвига?
    чтобы можно было его использовать как консьюмер, если вдруг делать шифрилку с плагинами, доимплементить в нём интерфейсик и вуаля )

    ps: да и последнее время надоели мне статики )
    Запись от mutagen размещена 16.11.2013 в 14:54 mutagen вне форума
 
Новые блоги и статьи
Как сделать UPDATE из SELECT в SQL Server
hw_wired 24.01.2025
В современных системах управления базами данных операции обновления и выборки данных являются фундаментальными инструментами для работы с информацией. SQL Server предоставляет мощные команды UPDATE и. . .
Как вставить элемент в массив на указанный индекс в JavaScript
hw_wired 24.01.2025
Массивы являются одной из фундаментальных структур данных в JavaScript, предоставляющей разработчикам мощный инструмент для хранения и управления упорядоченными наборами данных. Они позволяют хранить. . .
Чем отличаются HashMap и Hashtable в Java
hw_wired 24.01.2025
В мире разработки на Java существует множество инструментов для работы с коллекциями данных, и среди них особое место занимают структуры данных для хранения пар ключ-значение. HashMap и Hashtable. . .
Как конвертировать видео в GIF
hw_wired 24.01.2025
В современном мире анимированные изображения стали неотъемлемой частью цифровой коммуникации. Формат GIF (Graphics Interchange Format) представляет собой особый тип файлов, который позволяет. . .
Как скопировать текст в буфер обмена на JavaScript во всех браузерах
hw_wired 24.01.2025
Копирование текста в буфер обмена стало неотъемлемой частью современных веб-приложений, значительно улучшающей пользовательский опыт и упрощающей работу с контентом. В эпоху активного обмена. . .
Как скрыть клавиатуру на Android
hw_wired 24.01.2025
При разработке Android-приложений часто возникает необходимость управлять видимостью экранной клавиатуры для улучшения пользовательского опыта. Одним из наиболее эффективных способов контроля. . .
Как обучить нейросеть создания картинок на Python
bytestream 24.01.2025
В эпоху цифровых технологий искусственный интеллект становится неотъемлемой частью творческого процесса. Особое место в этой области занимает разработка и обучение нейронных сетей для создания. . .
Как обучить нейросеть генерации текста на Python
bytestream 24.01.2025
В современном мире искусственный интеллект и машинное обучение становятся неотъемлемой частью многих технологических решений. Одной из наиболее интересных и востребованных задач в этой области. . .
Машинное обучение на Python
bytestream 24.01.2025
Введение в машинное обучение на Python Машинное обучение представляет собой одну из наиболее динамично развивающихся областей информационных технологий, которая позволяет компьютерным системам. . .
Как удалить вирус-майнер с компьютера
hw_wired 24.01.2025
Вирусы-майнеры стали одной из наиболее серьезных угроз для пользователей компьютеров. Эти вредоносные программы тайно используют вычислительные ресурсы зараженного устройства для добычи криптовалюты. . .
Что такое веб-сервер, для чего он нужен и как работает
bytestream 24.01.2025
В современную эпоху цифровых технологий веб-сервер является фундаментальным компонентом интернет-инфраструктуры, обеспечивающим функционирование множества онлайн-сервисов и веб-сайтов. Этот. . .
Как в цикле for перебрать все элементы в словаре в Python
bytestream 24.01.2025
Словари в Python представляют собой мощные структуры данных, которые позволяют хранить информацию в формате ключ-значение. Эта особенность делает их незаменимыми при работе с данными, где требуется. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru