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

Определите тип данных, представляющий информацию о карте в карточной игре

18.06.2020, 12:39. Показов 3128. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Определите тип данных, представлющий информацию о карте в карточной игре. Каждая карта характеризуется одной из четырех мастей. Карта может быть либо младшей (от двойки до десятки), либо картинкой (валет, дама, король, туз). Определите функции:
1)Функция isMinor, проверяющая, что ее аргумент является младшей картой.
2)Функция sameSuit, проверяющая, что переданные в нее карты — одной масти.
3)Функция beats : : Card -> Card -> Bool, проверяющая, что карта, переданная ей в качестве первого аргумента, бьет карту, являющуюся вторым аргументом.
4)Функция beats2. аналогичная beats, но принимающая в качестве дополнительного аргумента козырную масть.
5)Функция beatsList, принимающая в качестве аргументов список карт, карту и козырную масть и возвращающая список тех карт из первого аргумента, которые бьют указанную карту с учетом козырной масти.
6)Функция, по заданному списку карт возвращающая список чисел, каждое из которых является возможной суммой очков указанных карт, рассчитанных по правилам игры в «двадцать одно»: младшие карты считаются по номиналу, валет, дама и король считаются за 10 очков, туз может рассматриваться и как 1 и как 11 очков. Функция должна вернуть все возможные варианты.

Не могу разобраться с двумя последними функциями(5 и 6). Что нужно в них вводить. Недавно начал изучать язык.

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
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
module Cards
( CardNum(..)
, CardSuit(..)
, Card(..)
, isMinor
, sameSuit
, beats
, beats2
, beatsList
, points
) where
 
import Data.List
 
data CardNum
    = Two
    | Three
    | Four
    | Five
    | Six
    | Seven
    | Eight
    | Nine
    | Ten
    | Jack
    | Queen
    | King
    | Ace
    deriving (Read, Show, Eq, Enum, Ord)
 
data CardSuit
    = Diamonds -- буби
    | Hearts   -- черви
    | Spider   -- пики
    | Clubs    -- крести
    deriving (Read, Show, Eq)
 
data Card = Card CardNum CardSuit deriving (Read, Show, Eq)
 
isMinor :: Card -> Bool
isMinor (Card t _)  = t < Jack
 
sameSuit :: Card -> Card -> Bool
sameSuit (Card _ s1) (Card _ s2)  =  s1 == s2
 
beats :: Card -> Card -> Bool
beats (Card n1 s1) (Card n2 s2)  =  s1 == s2 && n1 > n2
 
beats2 :: Card -> Card -> CardSuit -> Bool
beats2 (Card n1 s1) (Card n2 s2) s
    | s1 == s2   =  n1 > n2
    | s1 == s    =  True
    | otherwise  =  False
 
beatsList :: [Card] -> Card -> CardSuit -> [Card]
beatsList cs c s  =  filter (\x -> beats2 x c s) cs
 
 
 
crossMap :: (a -> b -> c) -> [a] -> [b] -> [c]
crossMap fn xs ys  =  rec [] xs ys
    where
        rec rs   _      []    =  rs
        rec rs   []   (y:ys)  =  rec rs xs ys
        rec rs (x:xs)   ys    =  rec ((x `fn` head ys) : rs) xs ys
 
addPoints :: [Int] -> [Int] -> [Int]
addPoints  =  crossMap (+)
 
pointsOf :: CardNum -> [Int]
pointsOf Jack   =  [10]
pointsOf Queen  =  [10]
pointsOf King   =  [10]
pointsOf Ace    =  [1, 11]
pointsOf cn     =  [fromEnum cn + 2]
 
points :: [CardNum] -> [Int]
points xs  =  sort $ nub $ rec [] xs
    where
        rec rs   []    =  rs
        rec [] (x:xs)  =  rec (pointsOf x) xs
        rec rs (x:xs)  =  rec (addPoints rs $ pointsOf x) xs
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.06.2020, 12:39
Ответы с готовыми решениями:

Определите тип данных, представлющий информацию о карте в карточной игре
Определите тип данных, представлющий информацию о карте в карточной игре. Каждая карта характеризуется одной из четырех мастей. Карта может...

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

Определить тип данных, представляющий информацию об иерархии классов
Здравствуйте! Суть задачи: Определить тип данных, представляющий информацию об иерархии классов. Описать следующие функции: 1)...

2
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38173 / 21108 / 4307
Регистрация: 12.02.2012
Сообщений: 34,704
Записей в блоге: 14
18.06.2020, 14:26
Все та же лабораторка....

Что делает beatsList?

Она принимает список карт ([Card]), конкретную карту (2-й параметр) и масть козыря (3-й параметр). Возвращает список тех карт, которые бьет карта-заданная вторым параметром с учетом козырной масти.
1
Модератор
 Аватар для Curry
5158 / 3479 / 536
Регистрация: 01.06.2013
Сообщений: 7,542
Записей в блоге: 9
18.06.2020, 16:00
Цитата Сообщение от Catstail Посмотреть сообщение
Все та же лабораторка....
Да ... уж ...
Переделать в функции высшего порядка
Как переписать функцию высших порядков в обычную Haskell
Написать программу не используя функции высшего порядка
Как вызвать пользовательский тип (data) в функции
Функции для работы со списками и игральные карты
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.06.2020, 16:00
Помогаю со студенческими работами здесь

Тип переменной для колоды в карточной игре
Пишу карточную игру, необходима переменная deck, из которой карты доставать(с удалением из переменной) можно по очереди, доставать...

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

Разработать тип данных Prop, представляющий утверждения заданного вида
Помогите пожалуйста. Утверждением будем называть логическую формулу, имеющую одну из следующих форм: • p &amp; q • p | q ...

Разработайте тип данных Prop, представляющий утверждения такого вида
Помогите пожалуйста с заданиям,очень надо. Разработайте тип данных Prop, представляющий утверждения та- кого вида. Определите...

Разработать тип данных ,представляющий различные требования к объектам недвижимости
Доброго времени суток,помогите с заданием по haskell,пожалуйста,совсем тяжко с ним.Желательно полный рабочий код и,если не трудно,то с...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru