С Новым годом! Форум программистов, компьютерный форум, киберфорум
Prolog
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
vladimirfol
1

Исключить из листа подряд одинаковые, подряд идущие элементы. Почему мое решение неверно?

24.05.2012, 21:02. Показов 1268. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Задача:
исключить из списка подряд идущие элементы, например:
[1, 1, 1, 2, 2, 1, 1, 1, 3, 3, 4, 5, 1, 1] -->
[1, 2, 1, 3, 4, 5 ,1]


[1,1,1,1,1,1,2,2,2,2,2] -->
[1,2]

У меня почему то не работает мое решение (Visual Prolog).

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
implement main
    open core, console
 
domains 
    rList= real*.
 
class predicates
    foo:(rList, rList) procedure (i, o).
 
constants
    className = "main".
    classVersion = "".
 
clauses
    classInfo(className, classVersion).
 
    foo([], []) :- !. %пустой список - решение
    foo([X], [X]) :- !. %список из одного элемента и есть решение
    foo([X1, X2 | T1], [X1 | T2]) :- not(X1 = X2), foo([X2 | T1], T2). %если встретили элемент который не равен предыдущему (с конца) то добавляем его в ответ
    foo([X, X | T], L) :- foo([X | T], L). %если встертили эелемент который равен предыдущему - игнорируем
    %В предыдущей строке пишет ошибку "The predicate foo which declared as procedure, is actually determ"
 
clauses
    run():-
        console::init(),
        %stdio::write("A: "),
        %List=read(),
        List=[1,1,1,1,2,2,2,3,4,5,1,1,2,1,1,1],
        foo(List, A),
        write(A),
        programControl::sleep(3000),
        succeed().
end implement main
 
goal
    mainExe::run(main::run).
Укажите пожалуйста мне на ошибку.
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.05.2012, 21:02
Ответы с готовыми решениями:

Исключить все повторяющиеся, идущие подряд элементы дека
Создать список из целых чисел. Подсчитать количество пар соседних элементов, которые совпадают...

В таблице есть одинаковые идущие подряд элементы. Подсчитать их количество.
В таблице А(10) есть одинаковые идущие подряд элементы. Подсчитать их количество.

Необходимо «сжать» данную последовательность, объединив одинаковые подряд идущие элементы в блоки
Дана последовательность из N целых чисел. Необходимо «сжать» данную последовательность, объединив...

Найти и удалить одинаковые подряд идущие одинаковые цифры в матрице
Здравствуйте. Помогите мне пожалуйста в работе с двумерным массивом. Мне нужно найти и удалить...

2
2507 / 1483 / 37
Регистрация: 14.09.2009
Сообщений: 2,740
24.05.2012, 21:15 2
Что бы предикат мог считаться процедурой, надо, чтобы он всегда возвращал ответ. Конечно для foo это выполняется, но для компилятора то это не очевидно
Prolog
1
2
3
foo([X, X | T], L) :-!,foo([X | T], L). %если встертили эелемент который равен предыдущему - игнорируем
foo([X1, X2 | T1], [X1 | T2]) :- !,foo([X2 | T1], T2). %если встретили элемент который не равен предыдущему (с конца) то добавляем его в ответ
foo(L,L). %сюда попадаем только если длина списка <=1, но для компилятора это еще надо,что бы считать foo procedure
0
vladimirfol
24.05.2012, 21:32 3
Большое спасибо.
А то я чуть уже с ума не сошел.
24.05.2012, 21:32
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.05.2012, 21:32
Помогаю со студенческими работами здесь

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

Удалить подряд идущие одинаковые символы
var i: integer; s: string; procedure DS(s:string; i:integer); begin i:=1; repeat

Удалить подряд идущие одинаковые буквы
помогите,пожалуйста, с составлением программы: Оставить в данном слове из каждого набора одинаковых...

В массиве A=(a1, а2, ..., аn) удалить все подряд идущие отрицательные элементы, идущие вслед за минимальным элементом массива.
Помогите написать на паскале программу для: В массиве A=(a1, а2, ..., аn) удалить все подряд...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
Это работает. Скорость асинхронной логики велика. Вопрос видимо останется в стабильности. Плата - огонь!
Hrethgir 13.01.2025
По прошлому проекту в Logisim Evolution https:/ / www. cyberforum. ru/ blogs/ 223907/ blog8781. html прилагаю файл архива проекта в Gowin Eda. Восьмибитный счётчик из сумматора+ генератор сигнала. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru