Форум программистов, компьютерный форум, киберфорум
Lisp
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/8: Рейтинг темы: голосов - 8, средняя оценка - 4.50
 Аватар для Vaderkos
84 / 83 / 8
Регистрация: 31.03.2015
Сообщений: 447

Удалить элемент на определенной позиции

05.12.2015, 20:13. Показов 1628. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как можно удалить элемент из списка зная позицию этого элемента?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.12.2015, 20:13
Ответы с готовыми решениями:

Удалить элемент, находящийся на 5-ой позиции в списке
удалить элемент находящийся на 5ой позиции в списке

Удалить все символы после определённой позиции в массиве
Подскажите, как удалить все символы после определённой позиции в массиве? Не использвуя при этом функции библиотеки string. Вообще по...

Однонаправленный список. Операции: удалить элемент из заданной позиции, добавить элемент в заданную позицию,проверка на неравенство
Помогите. Есть одна написанная. Условия: Очередь. Операции: “+” добавить элемент ; “-“ удалить элемент ; bool() проверка «Пуста...

5
4528 / 3522 / 358
Регистрация: 12.03.2013
Сообщений: 6,038
05.12.2015, 20:27
Lisp
1
(nconc (subseq list 0 (1- pos)) (nthcdr pos list))
как-то так.
1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38180 / 21115 / 4307
Регистрация: 12.02.2012
Сообщений: 34,722
Записей в блоге: 14
05.12.2015, 20:32
Лучший ответ Сообщение было отмечено Vaderkos как решение

Решение

Lisp
1
2
3
(defun del-by-pos (lst pos)
  (if (null lst) nil
      (if (zerop pos) (cdr lst) (cons (car lst) (del-by-pos (cdr lst) (- pos 1))))))
2
4528 / 3522 / 358
Регистрация: 12.03.2013
Сообщений: 6,038
05.12.2015, 20:51
Лучший ответ Сообщение было отмечено Vaderkos как решение

Решение

В номинации «самое неэффективное решение» побеждает Catstail (рекурсия, причём нехвостовая в циклическом алгоритме).
В номинации «самою глючное решение» побеждает helter (два бага на одну строчку: не удаляется голова и ошибка при удалении элементов с номерами, превышающими длину списка +1).

Следующая попытка:
Lisp
1
2
3
4
(loop :for x :in list
      :for i :from 0
      :unless (= i pos)
      :collect x)
2
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38180 / 21115 / 4307
Регистрация: 12.02.2012
Сообщений: 34,722
Записей в блоге: 14
05.12.2015, 21:12
Лучший ответ Сообщение было отмечено _sg как решение

Решение

Вот решение без рекурсии (и нечувствительное к выходу позиции за границы списка):

Lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
(defun del-by-pos (lst pos)
  (let ((res nil))
    (iter (for a in lst) (for c upfrom 0) (unless (= c pos) (collecting a into res)))
    res))
 
==> del-by-pos
 
(del-by-pos '(q w e r t y u i o p) 3)
 
==> (q w e T y u i o p)
 
(del-by-pos '(q w e r t y u i o p) 33)
 
==> (q w e r T y u i o p)
 
(del-by-pos '(q w e r t y u i o p) 0)
 
==> (w e r T y u i o p)
 
(del-by-pos '(q w e r t y u i o p) -50)
 
==> (q w e r T y u i o p)
В общем, то же самое...
2
 Аватар для _sg
4710 / 4405 / 380
Регистрация: 12.05.2012
Сообщений: 3,102
06.12.2015, 01:23
как вариант:
Lisp
1
2
3
4
5
6
7
8
9
10
11
(defun drop (w p &optional ac)
  (cond ((null w) (nreverse ac))
        ((zerop p) (append (nreverse ac) (cdr w)))
        ((drop (cdr w) (1- p) (cons (car w) ac)))))
 
> (drop '(1 2) 0)
(2)
> (drop '(1 2 3 4 5 6 7) 3)
(1 2 3 5 6 7)
> (drop '(1 2 3 4 5 6 7) 8)
(1 2 3 4 5 6 7)
Lisp
1
2
3
4
5
6
7
8
9
10
(defun drop (w p)
  (loop for a in w for b from 0
        unless (= b p) collect a))
 
> (drop '(1 2 3 4 5 6 7) 0)
(2 3 4 5 6 7)
> (drop '(1 2 3 4 5 6 7) 3)
(1 2 3 5 6 7)
> (drop '(1 2 3 4 5 6 7) 8)
(1 2 3 4 5 6 7)
Добавлено через 17 секунд
Lisp
1
2
3
4
5
6
7
8
9
10
11
(defun drop (w p)
  (if (and w (plusp p))
      (cons (car w) (drop (cdr w) (1- p)))
      (cdr w)))
 
> (drop '(1 2 3 4 5 6 7) 0)
(2 3 4 5 6 7)
> (drop '(1 2 3 4 5 6 7) 3)
(1 2 3 5 6 7)
> (drop '(1 2 3 4 5 6 7) 8)
(1 2 3 4 5 6 7)
Добавлено через 12 секунд
Lisp
1
2
3
4
5
6
7
8
9
10
11
(defun drop (w p &optional ac)
  (if (and w (plusp p))
      (drop (cdr w) (1- p) (cons (car w) ac))
      (append (nreverse ac) (cdr w))))
 
> (drop '(1 2 3 4 5 6 7) 0)
(2 3 4 5 6 7)
> (drop '(1 2 3 4 5 6 7) 3)
(1 2 3 5 6 7)
> (drop '(1 2 3 4 5 6 7) 8)
(1 2 3 4 5 6 7)
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.12.2015, 01:23
Помогаю со студенческими работами здесь

Скопировать часть строки с определенной позиции и определенной длины в другую строку
Ввести с клавиатуры строку. Скопировать часть строки с определенной позиции и определенной длины в другую строку. Номер позиции и...

Строка: Скопировать часть строки с определенной позиции и определенной длины в другую строку
Скопировать часть строки с определенной позиции и определенной длины в другую строку. Например: дана строка "Функция для работы со...

Удалить элемент из списка с указанной пользователем позиции
1) Создать очередь, заполнив числами 1,2,...,n. Проссмотреть её содержимое, удалить очередь. 2) Создать список, заполнив с помощью...

Списки. Удалить b элемент из k позиции, сделать проверку
Дан список, добавить k элемент в p позицию, сделать проверку, что эта позиция существует. Удалить b элемент из k позиции, сделать проверку....

Удалить из исходного списка элементы, начиная с позиции K до позиции N
Удалить из исходного списка элементы, начиная с позиции K до позиции N


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru