You need to enable JavaScript to run this app.
最新活动
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

如何设计“coin-change”问题的hylo解决方案?

“Coin-change”问题是指给定一定数量的不同硬币面值,要求找到以最少的硬币数量组成给定金额的方案。这个问题可以用递归或动态规划来解决,但都存在时间复杂度较高和内存占用较大的问题。

为了解决这个问题,可以使用“hylo”解决方案。Hylo是一种组合了递归和动态规划思想的解决方案,可以在避免资源浪费的情况下,以优秀的时间复杂度解决该问题。

下面给出具体的代码实现:

{-# LANGUAGE DeriveFunctor #-}

data Cofree f a = a :< f (Cofree f a)
    deriving Functor

anaC :: Functor f => (a -> f a) -> (a -> Cofree f b) -> a -> Cofree f b
anaC psi phi z = case phi z of
    b :< fz -> b :< fmap (anaC psi phi) (psi z)

type ListF a x = Maybe (a, x)

toListF :: [a] -> ListF a [a]
toListF [] = Nothing
toListF (x:xs) = Just (x, xs)

coinChange :: [Int] -> Int -> Maybe [Int]
coinChange coins amount = reduce res
  where
    res = anaC (toListF . select coins amount) (phi coins) amount

phi :: [Int] -> Int -> ListF Int Int
phi coins 0 = Nothing
phi coins n = case mfilter (<= n) coins of
    [] -> Nothing
    (c:cs) -> Just (c, n-c)

select :: [Int] -> Int -> [Int] -> [Int]
select coins n [] = []
select coins n (x:xs) | n < x = select coins n xs
                      | otherwise = x : select coins (n-x) (x:xs)

reduce ::
本文内容通过AI工具匹配关键字智能整合而成,仅供参考,火山引擎不对内容的真实、准确或完整作任何形式的承诺。如有任何问题或意见,您可以通过联系service@volcengine.com进行反馈,火山引擎收到您的反馈后将及时答复和处理。
展开更多
面向开发者的云福利中心,ECS 60元/年,域名1元起,助力开发者快速在云上构建可靠应用

社区干货

特惠活动

热门爆款云服务器

100%性能独享,更高内存性能更佳,学习测试、web前端、企业应用首选,每日花费低至0.55元
60.00/1212.00/年
立即购买

域名注册服务

cn/top/com等热门域名,首年低至1元,邮箱建站必选
1.00/首年起32.00/首年起
立即购买

DCDN国内流量包100G

同时抵扣CDN与DCDN两种流量消耗,加速分发更实惠
2.00/20.00/年
立即购买

如何设计“coin-change”问题的hylo解决方案? -优选内容

如何设计“coin-change”问题的hylo解决方案? -相关内容

特惠活动

热门爆款云服务器

100%性能独享,更高内存性能更佳,学习测试、web前端、企业应用首选,每日花费低至0.55元
60.00/1212.00/年
立即购买

域名注册服务

cn/top/com等热门域名,首年低至1元,邮箱建站必选
1.00/首年起32.00/首年起
立即购买

DCDN国内流量包100G

同时抵扣CDN与DCDN两种流量消耗,加速分发更实惠
2.00/20.00/年
立即购买

产品体验

体验中心

云服务器特惠

云服务器
云服务器ECS新人特惠
立即抢购

白皮书

一图详解大模型
浓缩大模型架构,厘清生产和应用链路关系
立即获取

最新活动

爆款1核2G共享型服务器

首年60元,每月仅需5元,限量秒杀
立即抢购

火山引擎增长体验专区

丰富能力激励企业快速增长
查看详情

数据智能VeDI

易用的高性能大数据产品家族
了解详情

一键开启云上增长新空间

立即咨询