SML—括号最大匹配距离问题(一)

本文介绍了一种暴力求解算法,用于匹配括号序列并计算最大匹配距离。该算法通过递归方式检查每一对括号是否正确匹配,并寻找最长的有效括号子序列。
部署运行你感兴趣的模型镜像


暴力求解算法

fun parenMatch (parens : paren seq) : bool =
  let
   fun pm ((NONE, _) | (SOME 0, CPAREN)) = NONE
      | pm (SOME c, CPAREN) = SOME (c-1)
      | pm (SOME c, OPAREN) = SOME (c+1)
  in
      iter pm (SOME 0) parens = (SOME 0)
  end

fun parenDist (parens : paren seq) : int option =
 let
   val n = Seq.length parens
   fun myBF(i,j,max) = case (parenMatch (Seq.subseq parens (i,j))) of
       false => if i = n-1 then NONE
       else if j<n-i then myBF(i,j+1,max)
       else myBF(i+1,1,max)
       |true => if j=n-i then Option210.intMax(max,SOME(j-2))
       else myBF(i+j,1,Option210.intMax(max,SOME(j-2)))
 in
  if parenMatch parens then myBF(0,1,NONE)
  else NONE
 end

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值