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

LinkedList время работы remove()

16.05.2017, 19:52. Показов 2101. Ответов 6

Студворк — интернет-сервис помощи студентам
Задание было написать свой LinkedList и сравнить его время работы с временем стандартного LinkedList.
У меня получилось, что мой метод remove() работает быстрее стандартного. Задача - объяснить почему так происходит.

Здесь объявление нового класса и способ хранения и доступа к данным
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
public class MyLinkedList<T> {
    private class Node {
        public T cargo;
        public Node next;
 
        public Node(T cargo) {
            this.cargo = cargo;
            this.next = null;
        }
 
        public Node(T cargo, Node next) {
            this.cargo = cargo;
            this.next = next;
        }
    }
 
    private Node getNode(int index) {
        if (index < 0 || index >= size) {
            throw new IndexOutOfBoundsException();
        }
        Node node = head;
        for (int i = 0; i < index; i++) {
            node = node.next;
        }
        return node;
    }
 
    private int size;
    private Node head;
 
    public MyLinkedList() {
        head = null;
        size = 0;
    }
Здесь мой метод
Java
1
2
3
4
5
6
7
8
9
10
11
public T remove(int index) {
        T element = get(index);
        if (index == 0) {
            head = head.next;
        } else {
            Node node = getNode(index - 1);
            node.next = node.next.next;
        }
        size--;
        return element;
    }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.05.2017, 19:52
Ответы с готовыми решениями:

LinkedList: метод remove не удаляет нужное значение
В чем может быть ошибка...но не корректно работает метод .remove он не удаляет нужное значение for(int i=0;i&lt;symbols.size();i++) ...

Свойства remove i contains в LinkedList.
Pomogite po4emu ne rabotaet metodi remove i contains ?Vozvrashajut false ? package myHomeWork; import java.util.LinkedList; import...

List.remove() vs asList.remove()
Всем привет. Хотел решить одну задачку тут на форуме, но что-то у меня все из рук валится, и в переносном смысле тоже. Немного...

6
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
16.05.2017, 19:55
Цитата Сообщение от Qwelia Посмотреть сообщение
У меня получилось, что мой метод remove() работает быстрее стандартного.
с чего это вдруг?

Добавлено через 51 секунду
ыы, получилось что быстрее, но почему не знаем
0
0 / 0 / 0
Регистрация: 03.04.2017
Сообщений: 7
16.05.2017, 20:04  [ТС]
это main, где и сравниваю время
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
MyLinkedList<Integer> mylist = new MyLinkedList<>();
        LinkedList<Integer> list = new LinkedList<>();
        mylist.add(15);
        mylist.add(3);
        list.add(15);
        list.add(3);
        
        System.out.println("remove: ");
        long start2 = System.nanoTime();
        mylist.remove(1);
        long end2 = System.nanoTime();
        long traceTime2 = end2 - start2;
        System.out.println("myList: " + traceTime2);
 
        long start3 = System.nanoTime();
        list.remove(1);
        long end3 = System.nanoTime();
        long traceTime3 = end3 - start3;
        System.out.println("List: " + traceTime3);
и такие результаты
Изображения
 
0
164 / 170 / 139
Регистрация: 28.11.2016
Сообщений: 301
16.05.2017, 20:17
Потому что в оригинальном LinkedList выполняется больше операций.

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
E unlink(Node<E> x) {
        // assert x != null;
        final E element = x.item;
        final Node<E> next = x.next;
        final Node<E> prev = x.prev;
 
        if (prev == null) {
            first = next;
        } else {
            prev.next = next;
            x.prev = null;
        }
 
        if (next == null) {
            last = prev;
        } else {
            next.prev = prev;
            x.next = null;
        }
 
        x.item = null;
        size--;
        modCount++;
        return element;
    }
1
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
16.05.2017, 20:20
асимптотически разницы нет. Лист из jdk двусвязный, у вас односвязный, как следствие больше оверхеда
1
502 / 348 / 134
Регистрация: 14.06.2016
Сообщений: 669
16.05.2017, 20:41
Ты попробуй последовательно удалять последние элементы на большом LinkedList и своем листе.
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
16.05.2017, 21:05
измерять время выполнения одной операции на листе из двух элементов - это конечно гениально. Для интереса повтори эксперимент тысячу раз и построй график в экселе.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.05.2017, 21:05
Помогаю со студенческими работами здесь

LinkedList Remove
Подскажите, пожалуйста, какой код нужен для того, чтобы из исходного списка (list1) удалять элементы, номера которых заданы значениями...

Реализовать аппликативный оператор MY-REMOVE-IF с интерфейсом и семантикой, аналогично стандартному REMOVE-IF
Реализовать аппликативный оператор MY-REMOVE-IF с интерфейсом и семантикой, аналогично стандартному REMOVE-IF.

Функция remove() удаляет только заранее запланированые файлы, выдавая ошибку на remove (STRING)
Салем, начал изучать файловую работу в С++, и столкнулся с такой проблемой, что функция remove() соглашается удалять только заранее...

Посчитать время события - время работы кассиров (система массового обслуживания)
Есть программа, моделирующая следующую задачу (система массового обслуживания): В бухгалтерии предприятия имеются два кассира, каждый...

Выводить текущее время в определенные позиции консоли во время работы
Портирую консольное приложение. Есть код, который работал после компиляции в BC++ 3.1, после компиляции под MinGW GCC программа не...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru