Форум программистов, компьютерный форум, киберфорум
Haskell
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 17.09.2016
Сообщений: 99

Переделать быструю сортировку

19.01.2018, 21:56. Показов 1243. Ответов 5

Студворк — интернет-сервис помощи студентам
Haskell
1
2
3
4
5
thirdElem (_,_,c) = c
 
qsort [] = []
qsort (h:t) = 
    qsort[x|x<-t, x<=h]++[h]++qsort[x|x<-t,x>h]
Функция быстрой сортировки, приведенная выше. прекрасно работает со списком чисел. Но что, если у нас есть некий кортеж , в котором третий элемент - число (Например, ('d','k',21)), то как переделать данную сортировку, чтобы она упорядочивала список кортежей из трёх элементов по возрастанию третьего эл-та в кортеже? Написал функцию therdElem, но вот приладить к qsort никак не получается
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.01.2018, 21:56
Ответы с готовыми решениями:

Пример на быструю сортировку
форумчане пожалуйста, приведите пример на быструю сортировку, на одномерный массив, заполненными случайными числами, состоящих из 10...

Можете обьяснить Быструю сортировку?
Алгоритм понял, но реализовать не получается?

Как оптимизировать быструю сортировку?
Помогите пожалуйста оптимизировать быструю сортировку. Какой лучше выбрать опорный элемент? #include &lt;iostream&gt; #include...

5
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,765
19.01.2018, 23:08
Цитата Сообщение от Bein Посмотреть сообщение
Функция быстрой сортировки, приведенная выше. прекрасно работает со списком чисел. Но что, если у нас есть некий кортеж , в котором третий элемент - число (Например, ('d','k',21)), то как переделать данную сортировку
Функцию сортировки переделывать не нужно никак. Нужно реализовать класс Ord для твоего типа кортежа.
1
Модератор
 Аватар для Curry
5156 / 3476 / 536
Регистрация: 01.06.2013
Сообщений: 7,537
Записей в блоге: 9
19.01.2018, 23:28
Лучший ответ Сообщение было отмечено Bein как решение

Решение

Haskell
1
2
3
4
5
6
7
8
thirdElem :: Ord a => (b,c,a) -> a
thirdElem (_,_,c) = c
 
qsort :: Ord a => [(b,c,a)] -> [(b,c,a)]
qsort [] = []
qsort (h:t) = 
    let third = thirdElem h in
    qsort[x|x<-t, thirdElem x <= third]++[h]++qsort[x|x<-t, thirdElem x > third]
Добавлено через 15 минут
Можем написать промежуточную, более универсальную функцию
Haskell
1
2
3
4
5
6
7
8
9
10
11
thirdElem :: Ord a => (b,c,a) -> a
thirdElem (_,_,c) = c
 
qsortF :: Ord a => (b -> a) -> [b] -> [b]
qsortF _ [] = []
qsortF f (h:t) = 
    let hv = f h in
    qsortF f [x|x<-t, f x <= hv] ++ [h] ++ qsortF f [x|x<-t, f x > hv]
 
qsort :: Ord a => [(b,c,a)] -> [(b,c,a)]
qsort = qsortF thirdElem
2
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,765
20.01.2018, 00:56
М-да, не ожидал, что Ord для (a,b,c) уже определён в GHC.Classes

Ну, как по мне, так лучше определить свой тип, хотя бы тупо врапнуть кортеж (а лучше сразу запись с полями, для информативности) и определить для него Ord. Проще будет ипользовать в предопределённых функциях.

Haskell
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
qsort [] = []
qsort (h:t) = 
    qsort [x | x <- t, x <= h] ++ [h] ++ qsort [x | x <- t, x > h]
 
data Foo = Foo (Char, Char, Int) deriving (Eq, Show)
 
data Bar = Bar {
    ch1 :: Char,
    ch2 :: Char,
    ord :: Int
} deriving (Eq, Show)
 
instance Ord Foo where
    compare (Foo (_, _, x)) (Foo (_, _, y)) = compare x y
 
instance Ord Bar where
    compare (Bar _ _ x) (Bar _ _ y) = compare x y
 
testDataFoo = [Foo ('d', 'k', 21), Foo ('a', 'b', 1), Foo ('x', 'y', 34)]
testDataBar = [Bar 'd' 'k' 21, Bar 'a' 'b' 1, Bar 'x' 'y' 34]
 
main = do
    print $ qsort testDataFoo
    print $ qsort testDataBar
https://ideone.com/MFXUZf

Code
1
2
[Foo ('a','b',1),Foo ('d','k',21),Foo ('x','y',34)]
[Bar {ch1 = 'a', ch2 = 'b', ord = 1},Bar {ch1 = 'd', ch2 = 'k', ord = 21},Bar {ch1 = 'x', ch2 = 'y', ord = 34}]
1
0 / 0 / 0
Регистрация: 17.09.2016
Сообщений: 99
20.01.2018, 11:38  [ТС]
KolodeznyDiver, поясните. пожалуйста, что происходит в этом коде. А именно, что такое Ord в 1 и 3 строке кода?

Haskell
1
2
3
4
5
6
7
8
thirdElem :: Ord a => (b,c,a) -> a
thirdElem (_,_,c) = c
 
qsort :: Ord a => [(b,c,a)] -> [(b,c,a)]
qsort [] = []
qsort (h:t) = 
    let third = thirdElem h in
    qsort[x|x<-t, thirdElem x <= third]++[h]++qsort[x|x<-t, thirdElem x > third]
0
Модератор
 Аватар для Curry
5156 / 3476 / 536
Регистрация: 01.06.2013
Сообщений: 7,537
Записей в блоге: 9
20.01.2018, 12:28
Цитата Сообщение от Bein Посмотреть сообщение
что такое Ord в 1 и 3 строке кода
Ord - класс типов, т.е. набор функций реализуемых отдельно для разных типов, и, в данном случае, относящихся к сравнению значений одного типа между собой
Haskell
1
2
3
4
5
6
7
8
class Eq a => Ord a where
  compare :: a -> a -> Ordering
  (<) :: a -> a -> Bool
  (<=) :: a -> a -> Bool
  (>) :: a -> a -> Bool
  (>=) :: a -> a -> Bool
  max :: a -> a -> a
  min :: a -> a -> a
Eq - это тоже класс типов.
Haskell
1
2
3
class Eq a where
  (==) :: a -> a -> Bool
  (/=) :: a -> a -> Bool
Если мы реализуем функции из Ord для нашего типа (говорят реализуем экземпляр (instance) класса типов для типа), то нужно сделать и instance Eq для этого типа. Для большинства стандартных типов (Int,Double,Char) экземпляры Eq, Ord уже реализованы. Для созданных нами типов компилятор часто может сделать (вывести) реализации этих и других стандартных классов типов если указать deriving.
В описании функций, например,
Haskell
1
qsort :: Ord a => [(b,c,a)] -> [(b,c,a)]
Ord a => означает что для типа третьего элемента кортежа должен быть реализован класс типов Ord (а значит и Eq). Тип может быть любой, но вот с таким ограничением потому что внутри функции будут вызываться (<=) и (>) для третьего элемента кортежа, и нужно знать, функции от какого instance Ord подставить. Что же касательно функции thirdElem, то для неё я это ограничение написал зря, она не обращается к функциям из Ord.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.01.2018, 12:28
Помогаю со студенческими работами здесь

Вставить быструю сортировку в программу
есть программа которая записывает сведение об абонентах телефонной сети в файл, нужно вставить быструю сортировку, чтоб сортировало по...

Поменять быструю сортировку на пузырьковую
Поменять быструю сортировку на пузырьковую. using System; using System.IO; using System.Text.RegularExpressions; namespace...

Как сделать быструю сортировку?
Как сделать быструю сортировку???

Максимально просто реализовать быструю сортировку
Максимально просто пытаюсь реализовать быструю сортировку без использования функций и подпрограмм. Если первый элемент больше, то поменять...

Как вставить счетчик в быструю сортировку?
нужно написать счетчик, какой определяет кол-во перестановок и сравнений в быстрой сортировке #include &lt;iostream&gt; #include...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью 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, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru