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

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

Запись от mutagen размещена 16.11.2013 в 13:55
Показов 5042 Комментарии 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 вне форума
 
Новые блоги и статьи
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
Модель здравосохранения 18. Чем здоровее работник, тем быстрее выгорает
anaschu 24.05.2026
Имитационная модель корпоративного здравоохранения: что показывает математика Сегодня в модели рабочего коллектива на AnyLogic появились три новые механики — выгорание через накопленную усталость,. . .
Модель здравосохранения 17. Планы на выгорание
anaschu 23.05.2026
Вот конкретная схема реализации: В классе Работник добавить: накопленнаяУсталость — растёт каждый час работы, снижается в перерывы и болезни коэффициентПрезентеизма — снижает продуктивность. . .
Изменение цветов в палитре gif файла aka фавикона
russiannick 23.05.2026
Изменение цветов в палитре gif файла, юзаемого как фавиконка в составе html-файла, помещенная в base64, средствами нативного Java Script, навеянное сном в майский день. Для работы необходим браузер,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru