- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图找出哪个整数列表更大。[1;2;3]
的表示实际上是 123
.
所以给定两个整数列表,我想比较每个元素以确定最终哪个数字更大。返回 1
如果 list1 > list2
, -1
如果 list1 < list2
, 和 0
如果他们是平等的。
这是我到目前为止所拥有的,但是当我尝试运行它时,我得到了错误,我不明白为什么。我还被要求尽可能以尾递归形式进行所有重复。这是正确的尾递归吗?
let rec compare' list1 list2 currentOrder = match (list1, list2) with
| [],[] -> 0
| list1, [] -> 1
| [], list2 -> -1
| car1::cdr1, car2::cdr2 -> (*car1 contains the current element and cdr1 contains the rest of the list. Ex car1 = [1], cdr2 = [2;3]*)
let nextCompare =
(
if cdr1 = [] && cdr2 = []
then 0
else 1
)
in
(
if (nextCompare != 0)(*To check if we are not at the end of the list*)
then ( (*Compare the cars to determine the currentOrder and recursively call with the next number*)
if car1 > car2
then (compare' (cdr1 cdr2 1))
else if car1 < car2
then (compare' (cdr1 cdr2 -1))
else (compare' cdr1 cdr2 currentOrder)
)
else (*we are at the end of the list so we want to return the current order*)
( (*Still need to check in case there is only 1 digit number, because we did not update currentOrder for it to be returned*)
if car1 > car2
then 1
else if car1 < car2
then -1
else currentOrder
)
)
Printf.printf (compare' [1;2;3] [3;2;1] 0)
最佳答案
您遇到的第一个问题是一些函数应用程序(例如 (compare' (cdr1 cdr2 1))
)的参数周围有一些额外的括号,它告诉 OCaml 您想调用 cdr1
带有参数 cdr2
和 1
,然后将结果应用到 compare'
.因此编译器会提示你试图使用列表 cdr1
作为一个函数。如果您习惯于使用括号来运行应用程序,这是一个简单的错误。
第二个问题是你有 -1
不带括号,编译器会将其解释为应用 1
到二进制 -
运算符,因此提示其结果是一个函数而不是一个 int,正如你所期望的那样。这种奇怪行为的原因是 OCaml 支持部分函数应用,这会导致一些歧义。消除歧义,您只需将其括在括号中:(-1)
.
最后,您的代码中有相当多的冗余,所以我为您简化了一些。更少的代码也意味着更少的地方可以搞砸,并且可以通过查看来找到搞砸的地方,这在你学习时非常方便:)
let rec compare' list1 list2 currentOrder =
match list1, list2 with
| [], [] -> currentOrder
| _, [] -> 1
| [], _ -> -1
| car1::cdr1, car2::cdr2 ->
let order =
if car1 > car2 then 1
else if car1 < car2 then -1
else currentOrder
in
compare' cdr1 cdr2 order
关于compiler-errors - 确定哪个整数列表更大,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46858617/
我在运行 compile test:compile it:compile经常并且...希望将击键次数减少到类似 *:compile 的数量。 .不过,它似乎不起作用。 $ sbt *:compile
有人可以给我这个问题的提示(或整个解决方案!): 在 Clojurescript 项目中,如何自动将编译日期/时间硬编码在符号中,以便在使用应用程序时显示? 谢谢。 最佳答案 有多种解决方案: 使用l
我是 ember.js 框架的新手,使用 ruby on rails 和 ember.debug.js -v 1.10.1(最新版本)。我一直在网上看到 ember 更改了这个最新的补丁,但我不知
我不是 Fortran 程序员(只是短暂的经验),但我需要编译一个部分用 F77 编写的程序。在我之前有人用 Absoft 编译器编译过它,但现在我需要在另一台机器上用 g77 重复这个过程。对于 A
我运行命令 mvn clean package 我得到了上面的错误我的 pom 是: http://maven.apache.org/xsd/maven-4.0.0.xsd"> 4.0.0
我有以下问题。 我想在测试编译阶段排除一些.java文件(** / jsfunit / *。java),另一方面,我想在编译阶段包括它们(id我使用tomcat启动tomcat:运行目标) ) 我的p
符合 wikipedia A compiler is a computer program (or set of programs) that transforms source code writt
我想构建项目,但出现如下错误: 无法执行目标 org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile
当我通过右键单击项目名称进行 Maven 安装时,出现以下错误: [INFO] Scanning for projects... [WARNING] [WARNING] Some proble
我是 Maven 的新手,我想将我的应用程序导入到 Maven。和以前一样,我想将我的 ejb 项目中的类引用到我的 war 项目中。我在类中没有错误,但是如果我在我的父项目上安装 maven,那么我
当我将 ASP.NET Web 应用程序部署到生产环境时,我使用配置转换来删除 debug="true"来自 .但是,就在今天,我注意到 web.config 中的另一个部分如下所示:
This question already has answers here: Maven Compilation Error: (use -source 7 or higher to enable
我正在使用 Maven 3.0.5 和 Spring Tool Source 3.2 并安装了 Maven 插件。当我尝试执行“运行方式---> Maven 安装”时,出现以下错误: [INFO] S
我试图用 AngularJS 创建我自己的递归指令,它调用自己以漂亮的 JSON 格式转换 View 中的对象。好吧,首先我使用 ng-include 调用带有模板的脚本,在其中使用 ng-if 验证
可以通过 @suppress annotation使用Google的Closure Compiler在每个文件的基础上禁止显示警告。但是,似乎无法同时抑制多个警告-例如globalThis和check
假设一个拥有 10 到 20 年经验的熟练开发人员从未构建过编译器或模拟器,哪一个会更具挑战性? 你能比较一下会成为障碍的问题吗? 谢谢。 最佳答案 仿真和编译是完全不同的,但由于两者都被认为是“低级
最近发现Vim中有一个命令叫compiler。您可以使用任何常见的编译器(例如,:compiler gcc、:compiler php 等)来调用它,但它似乎没有任何立竿见影的效果。 我在联机帮助页上
我试图从 spring.io 指南中部署最简单的应用程序 Guide 但是我有一些麻烦.. 我做了什么: 创建的项目。 (来自 spring.io 教程) 下载 heroku CLI 在 Intell
每当进行 Maven Build..>clean install 时,我都会遇到此错误。我尝试过使用不同版本的插件并添加 testFailureIgnore 属性,但问题仍然存在。请找到下面的 POM
我有一个 web 应用程序,我尝试使用 maven 进行编译,不幸的是,在执行 mvn clean package 时它不起作用。 stackoverflow 上有很多问题看起来都一样,但没有解决了我
我是一名优秀的程序员,十分优秀!