当前位置: 首页 > 编程笔记 >

OCaml 汇总列表中的数据

成浩漫
2023-03-14
本文向大家介绍OCaml 汇总列表中的数据,包括了OCaml 汇总列表中的数据的使用技巧和注意事项,需要的朋友参考一下

示例

的List.fold_left和List.fold_right功能是实现列表聚集的外逻辑高阶函数。汇总列表(有时也称为简化列表)意味着计算从对该列表中所有项目的顺序检查得出的值。

列表模块的文档指出:

  • List.fold_left f a [b1; ...; bn]是f (... (f (f a b1) b2) ...) bn。

  • List.fold_right f [a1; ...; an] b是f a1 (f a2 (... (f an b) ...))。(后一个函数不是尾递归的。)

用简单的英语来说,计算List.fold_left f a [b1; ...; bn]相当于遍历列表,并[b1; ...; bn]跟踪最初设置为的累加器a:每次看到列表中的项目时,我们都会使用f该值来更新累加器的值,完成后,累加器就是最终的累加器。计算的价值。该List.fold_right功能是相似的。

以下是一些实际示例:

计算数字列表的总和

List.fold_left ( + ) 0 lst

计算浮动列表的平均值

let average lst =
  let (sum, n) =
   List.fold_left(fun (sum, n) x -> (sum +. x, n + 1)) (0.0, 0) lst
  in
  sum /. (float_of_int n)

重新实现基本列表处理

函数List.fold_left和List.fold_right的通用性使得它们可以用于实现列表模块中的几乎所有其他函数:

let list_length lst = (* Alternative implementation toList.length*)
 List.fold_left( + ) 0 lst

let list_filter predicate lst = (* Alternative implementation toList.filter*)
 List.fold_right(fun a b -> if predicate a then a :: b else b) lst []

甚至有可能重新实现该List.iter功能,请记住,()程序的全局状态是将此代码解释为列表聚合的另一个示例:

let list_iter f lst = (* Alternation implementation toList.iter*)
 List.fold_left(fun () b -> f b) () lst

这些示例仅是学习材料,这些实现不具备标准库中相应功能的优点。

 类似资料:
  • 问题内容: 这是我的代码,我需要对列表中未定义数量的元素求和。这该怎么做? 我的输入: 输入后,我通过删除第一个元素。在列表之后,我需要对列表中的所有元素求和。 在这种情况下,总和为18。请注意,未定义元素数。 问题答案: 您可以使用内置的sum()来对列表中的数字求和: 它将汇总所有数量的项目。例: 对于您的具体情况 : 对于您的数据,首先将数字转换为数字,然后将数字求和: 这将适用于列表中 未

  • 问题内容: 在我的模型中,我的数据类似于: 我想显示带有复选框的标签列表(包含’tag1’和’tag2’的唯一值)。希望是这样的: 如果我对列表进行硬编码,我知道如何根据检查的内容过滤主列表,但是不知道如何自动生成唯一标签列表。 问题答案: 您正在寻找执行三个操作: 从中的每个项目获取标签数组 将它们展平为单个阵列 从此数组获取唯一值 您可以使用纯JavaScript来做到这一点,但是为了使事情变

  • 我有一个这样的数字列表: 如何以优雅的方式总结每个N(让我们假设2)个元素并将列表转换为: 编辑:我想出了以下解决方案: 它是有效的,但我仍然在寻找一个更易读、更简单的方法。

  • 问题内容: 在MySQL中,我有两个表: 和 我需要对表(等式7)和表(等式3)中的列求和,并将结果作为总数量。 当我做 我得到了笛卡尔积(20),但是我需要的正确答案是10。如何更改此查询以获得正确的结果? 问题答案:

  • 本文向大家介绍Python中列表(list)操作方法汇总,包括了Python中列表(list)操作方法汇总的使用技巧和注意事项,需要的朋友参考一下 本文实例汇总了Python中关于列表的常用操作方法,供大家参考借鉴。具体方法如下: 一、Python创建列表: 二、Python 列表操作: 假设有如下列表: 1.得到列表中的某一个值: 2.删除列表的第一个值: 3.在列表中插入一个值: 4.得到列表

  • 关于如何利用函数汇总表的数据。 聚集函数 确定表中的行数 获得表中行组的和 找出表列(所有行,特定行)的最大,最小,平均值。 上面的例子需要对表中的数据汇总,而不是实际数据本身,所以可以不需要返回时间数据,浪费资源 聚集函数(aggregate function) 运行在行组上,计算和返回单个值的函数。 AVG(): 返回所有列或者某个列平均值。 计算表中的行数并计算特定列值之和,求得改列的平均值