Форум программистов, компьютерный форум, киберфорум
Prolog
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 1
Регистрация: 06.03.2020
Сообщений: 56

Как удалить все вхождения элемента в список

22.10.2020, 21:11. Показов 1328. Ответов 0

Студворк — интернет-сервис помощи студентам
Здравствуйте.

Подскажите , на пальцах пожалуйста , как удалить все вхождения элемента в список.

Вот код:

Prolog
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
% Copyright
 
implement main
    open core
 
domains
    integer_list = integer*.
 
class predicates
    set_of_numbers : (integer_list List [out]).
clauses
    set_of_numbers([5, 4, 3, 2, 1, 0, 1, 2, 3, 4]).
 
class predicates
    length : (integer_list List, integer Length [out]).
clauses
    length([], 0).  %
    length([_ | Tail], Length) :-
        length(Tail, TailLength),
        Length = TailLength + 1.
 
class predicates
    append : (integer ElementToInsert, integer_list List, integer_list NewList [out]).
clauses
    append(Element, [], [Element]) :-
        !.
    append(Element, List, [Element | List]).
 
class predicates
    delete : (integer ElementToDelete, integer_list List, integer_list NewList [out]) determ.
clauses
    delete(Element, [Element | Tail], Tail) :-
        !.
    delete(Element, [Head | Tail], [Head | Tail1]) :-
        delete(Element, Tail, Tail1).
 
class predicates
    isMember : (integer ElementToSearchFor, integer_list List) determ.
clauses
    isMember(ElementToSearchFor, [ElementToSearchFor | _]) :-
        !.
    isMember(ElementToSearchFor, [_ | Tail]) :-
        isMember(ElementToSearchFor, Tail).
 
class predicates
    concatenate : (integer_list ListToMerge, integer_list OriginalList, integer_list ResultingList [out]).
clauses
    concatenate([], OriginalList, OriginalList).
    concatenate([H | Tail1], OriginalList, [H | Tail3]) :-
        concatenate(Tail1, OriginalList, Tail3).
 
clauses
    run() :-
        console::init(),
        fail.
 
    run() :-
        set_of_numbers(OriginalList),
        length(OriginalList, Length),
        stdio::writef('\nДлина списка: %\n', Length),
        stdio::write('\nВведите целое число для вставки в список: '),
        ElementToInsert = stdio::read(),
        append(ElementToInsert, OriginalList, NewList),
        stdio::writef('\nИзмененный список: %\n', NewList),
        stdio::write('\nВведите целое число для удаления из списка: '),
        ElementToDelete = stdio::read(),
        if delete(ElementToDelete, OriginalList, ResultingList) then
            stdio::write("\nЭлемент удален\n"),
            stdio::writef('\nИзмененный список: %\n', ResultingList)
        else
            stdio::write("\nТакого элемента в списке нет\n")
        end if,
        stdio::write('\nВведите целое число для поиска в списке: '),
        ElementToSearch = stdio::read(),
        if isMember(ElementToSearch, OriginalList) then
            stdio::write("\nЭлемент находится в списке\n")
        else
            stdio::write("\nТакого элемента в списке нет\n")
        end if,
        fail.
 
    run() :-
        set_of_numbers(OriginalList),
        stdio::write('\nВведите список целых чисел для объединения с исходным списком: '),
        ListToAppend = stdio::read(),
        concatenate(ListToAppend, OriginalList, NewList),
        stdio::writef("\nПолученный список: %\n", NewList).
 
end implement main
 
goal
    console::runUtf8(main::run).
Вот сам предикат удаления, куда нужно добавить какое-то правило.

Prolog
1
2
3
4
5
6
7
class predicates
    delete : (integer ElementToDelete, integer_list List, integer_list NewList [out]) determ.
clauses
    delete(Element, [Element | Tail], Tail) :-
        !.
    delete(Element, [Head | Tail], [Head | Tail1]) :-
        delete(Element, Tail, Tail1).
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.10.2020, 21:11
Ответы с готовыми решениями:

Удалить все вхождения элемента X в список L.([121234],2) -> [1134])
Помогите реализовать программу удаления всех вхождений заданного элемента в список. Спасибо

Дописать в список L после первого вхождения элемента Еl список L1 и удалить из L все оставшиеся элементы El
Дописать в список L после первого вхождения элемента Еl список L1 и удалить из списка L все оставшиеся элементы Еl.

Сформировать непустой список L по принцепу стека. Удалить из списка L все вхождения элемента E
Сформировать непустой список L по принцепу стека. Удалить из списка L все вхождения элемента E. Вывести список до и после изменений....

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.10.2020, 21:11
Помогаю со студенческими работами здесь

Удалить из нее все вхождения максимального элемента
Дана последовательность из n целых элементов. Удалить из нее все вхождения максимального элемента, затем отсортировать ее по возрастанию....

Удалить все вхождения элемента в односвязном списке
Нужна функция для удаления всех вхождений элемента в односвязном списке

Рекурсия: удалить из списка (цепочки) L все вхождения элемента Е
Описать рекурсивную функцию, которая удаляет из списка (цепочки) L все вхождения элемента Е.

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

Удалить из списка все вхождения элемента, значение которого вводится с клавиатуры
Нужно создать программу динамических структур списка для удаления из него всех вхождений элемента, значение которого вводится с клавиатуры.


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru