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

Ошибка в реализации быстрой сортировки

02.11.2010, 19:11. Показов 971. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Сортирует список быстрой сортировкой, результирующий список - Ls. Вместо результата при вызове цели выводится false... Что это значит, и как заставить его выводить список? В других сортировках такого не было.
Prolog
1
2
3
4
5
6
7
8
9
10
qsort([],[]).
qsort([H|T],Ls):-split(H,T,S,B),qsort(S,S1),qsort(B,B1),append(S1,[X|B1],Ls).
split(H,[A|T],[A|S],B):- H>A,split(H,T,S,B).
split(H,[A|T],S,[A|B]):-H<=A,split(H,T,S,B).
split(_,[],[],[]).
 
write_list([]):-nl.
write_list([H|T]):-write(H),write('   '),write_list(T).
 
goal:-qsort([1,6,9,3,4,2],M),write_list(M).
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.11.2010, 19:11
Ответы с готовыми решениями:

Ошибка StackOverflowException при реализации быстрой сортировки
Здравствуйте, уже несколько дней пытаюсь разобраться в чём дело. Выдаёт ошибку StackOverflowException Сам код: class Program { ...

Различные реализации быстрой сортировки
Доброго времени суток! Необходимо реализовать быструю сортировку: ////1//// По выбору опорного элемента: mid * средний элемент в...

Написать код реализации быстрой сортировки
Помогите написать код реализации быстрой сортировки на ассемблере

8
 Аватар для Грымзик
2507 / 1483 / 37
Регистрация: 14.09.2009
Сообщений: 2,740
02.11.2010, 19:45
Ошибка тут append(S1,[X|B1],Ls), надо append(S1,[H|B1],Ls). А что это за диалект такой? Просто обычно нельзя писать <=, надо =<.
2
1 / 1 / 0
Регистрация: 27.02.2010
Сообщений: 8
02.11.2010, 19:53  [ТС]
Просто обычно нельзя писать <=, надо =<.
Вы мне вот этим замечанием исправили ошибку в ещё одной проге, над которой я как раз бьюсь))
0
1 / 1 / 0
Регистрация: 27.02.2010
Сообщений: 8
11.11.2010, 20:42  [ТС]
А как сделать так, чтобы после вывода отсортированного списка не вылезало дополнительное "тру"? отсечение в конце goal не помогло.
0
Українець
424 / 318 / 16
Регистрация: 26.09.2009
Сообщений: 844
11.11.2010, 20:50
Prolog
1
...,!,fail.
0
 Аватар для Грымзик
2507 / 1483 / 37
Регистрация: 14.09.2009
Сообщений: 2,740
11.11.2010, 20:57
Да вроде никак, разве если что считывать после этого что-нибудь, но это уж точно не лучше.

Добавлено через 4 минуты
fail ничего хорошего не даст, будет просто выводиться false, какая разница.
0
Українець
424 / 318 / 16
Регистрация: 26.09.2009
Сообщений: 844
11.11.2010, 21:01
Вот пример
Prolog
1
2
3
4
5
6
predicates
x(integer)
clauses
x(1).
goal
x(1),!,fail.
1
 Аватар для Грымзик
2507 / 1483 / 37
Регистрация: 14.09.2009
Сообщений: 2,740
11.11.2010, 21:29
freest, спасибо за пример, я не знала, что в визуал прологе можно избавиться от вывода yes/no, но в данной теме обсуждается SWI пролог.
1
Українець
424 / 318 / 16
Регистрация: 26.09.2009
Сообщений: 844
11.11.2010, 21:32
Упс)) Сори=)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.11.2010, 21:32
Помогаю со студенческими работами здесь

Ошибка на этапе выполнения быстрой сортировки
Ошибка а не пойму в чем,код здеясь:#include&lt;iostream&gt; using namespace std; void main(){ setlocale(LC_ALL, &quot;Ukrainian&quot;); ...

Метод быстрой сортировки: В чем ошибка?
В Паскале я ниачем, нашел метод быстрой сортировки, нужно скоро сдавать, компелятор говорит что там 3 ошибки кому не трудно исправьте...

Метод быстрой сортировки. Подскажите где ошибка?
Не могу понять где ошибка? using System; namespace ConsoleApplication67 { class Program { static void...

Ошибка в реализации сортировки выбором
Опять не вижу ошибки в коде. Выдает ту же числовую последовательность program sortirovka implicit none real(8) item,cnt Integer,...

Ошибка в реализации сортировки слиянием
Перевел с паскаля на vb.net сортировку вставками Вот что получилось Sub MergeSort(ByRef d() As Double) Dim m, n, k As Long ...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru