Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.61/18: Рейтинг темы: голосов - 18, средняя оценка - 4.61
88 / 86 / 55
Регистрация: 14.11.2015
Сообщений: 1,099

Вставка элемента в LinkedList

27.11.2016, 11:16. Показов 3331. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В javadoc написано, что LinkedList - имплементация двухсвязного списка.

Допустим, у меня список из 10.000 элементов и я хочу вставить элемент на 9.998 позицию. Как я понял, LinkedList будет перебирать все элементы до 9.998, а не пойдет с хвоста назад. Сорцы:
Java
1
2
3
4
5
6
7
8
    public void add(int index, E element) {
        checkPositionIndex(index);
 
        if (index == size)
            linkLast(element);
        else
            linkBefore(element, node(index));
    }
Java
1
2
3
4
5
6
7
8
9
10
11
12
    void linkBefore(E e, Node<E> succ) {
        // assert succ != null;
        final Node<E> pred = succ.prev;
        final Node<E> newNode = new Node<>(pred, e, succ);
        succ.prev = newNode;
        if (pred == null)
            first = newNode;
        else
            pred.next = newNode;
        size++;
        modCount++;
    }
Java
1
2
3
4
private void checkPositionIndex(int index) {
        if (!isPositionIndex(index))
            throw new IndexOutOfBoundsException(outOfBoundsMsg(index));
    }
Мы можем получить размер листа за O(1). Почему разработчики не сделали проверку на нахождение индекса элемента? В моем случае index > list.size()/2, соотвественно можно идти с хвоста назад.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.11.2016, 11:16
Ответы с готовыми решениями:

Вставка элемента
Есть связный список, в который надо вставить элемент после определенного. То есть, я нахожу элемент и вставляю после него. Поиск элемента,...

Вставка элемента в Список
import java.util.ArrayList; import java.util.Random; import java.util.Scanner; public class T1 { public static void main(String...

Вставка элемента в середину массива
есть массив состоящий из 10 интов 12 85 66 12 44 0 0 0 0 0 как вставить новый элемент(напр. 25) на вторую позицию при этом остальные...

1
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
27.11.2016, 11:28
Цитата Сообщение от Artmal Посмотреть сообщение
Почему разработчики не сделали проверку на нахождение индекса элемента?
очень даже сделали

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
  Node<E> node(int index) {
        // assert isElementIndex(index);
 
        if (index < (size >> 1)) {
            Node<E> x = first;
            for (int i = 0; i < index; i++)
                x = x.next;
            return x;
        } else {
            Node<E> x = last;
            for (int i = size - 1; i > index; i--)
                x = x.prev;
            return x;
        }
    }
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.11.2016, 11:28
Помогаю со студенческими работами здесь

Вставка элемента внутрь Arraylist
Здравствуйте. Задача кода такова, чтобы при нахождении в Arraylist'е определенного символа(в данном случае это &quot;+&quot;) перед ним...

Добавление и вставка элемента в коллекцию
Добрый день. Подскажите, пожалуйста, в чём отличие вставки и добавления элемента в коллекцию и почему в TreeMap можно вставить элемент, а в...

LinkedList
Имеем ЛинкедЛист кот-ый содержит допустим 15 элементов.Как вывести последние 10 элементов, а остальное не трогать?

Синхронизация LinkedList
Подскажите пожалуйста, в чем ошибка в данном выражении private LinkedList&lt;Point&gt; VisitedEdges = Collections.synchronizedList(new...

C linkedlist в arraylist
Доброго времени суток! подскажите пожалуйста, как правильно организовать выбор не повторяющихся элементов c linkedlist в arraylist? ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru