- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我遇到了以下问题:
编写一个函数,给定一个列表 l 和一个 int c,返回 min(|c+x1+x2|),其中 x1 和 x2 是列表中的一些值。 [也有可能 x1=x2]
我有一段代码显然可以解决这个问题:
let bestSum l c =
let rec f l lr res =
match (l,lr) with
| ([],lr) -> res
| (l,[]) -> res
| (h1::t1, h2::t2) -> if (h1+h2+c)>0 then f l t2 (min res (h1+h2+c)) else
f t1 lr (min res (-(h1+h2+c))) in
f l (rev l) (abs (2* (hd l) + c));;
凭直觉,我知道它的工作原理和原因,但我不确定它是否适用于所有可能的情况。那么如何正式证明呢?
编辑:是的,我忘了添加,列表已排序,抱歉。
最佳答案
我将假定您的列表已排序,否则它不起作用。这是对您的算法的描述,应该清楚说明您的程序为何有效。假设您的数字是 x[0], x[1], ... , x[n]
。目标是找到两个数字 x[i]
和 x[j]
,使它们的总和尽可能接近 -c
。让我们通过 (n + 1)
网格在 (n + 1)
中绘制值 x[i] + x[j] + c
,用 +
标记正值,用 -
标记负值(示例见下文)。目标是找到具有最小绝对值的单元格。
Example where c = 0, x = [-3, -2, 1, 4].
x[0] x[1] x[2] x[3]
x[0] - - - (+)
x[1] - - (-) (+)
x[2] (-) (-) (+) +
x[3] (+) + + +
您会注意到 -
和 +
分为两个区域,确实必须如此,因为每个单元格的值都较小而不是正下方或右侧的单元格。根据该观察,唯一可以优化的单元格是位于 -
和 +
之间边界的单元格。
您的算法基本上遵循此边界(您的算法考虑的单元格标记在括号中)。让我们来看看几个步骤:
首先,考虑x[3] + x[0]
。我们看到它是 +
,所以 x[3] + x[1]
不可能更好,试试 x[2] + x[0]
接下来。
x[0] x[1] x[2] x[3]
x[0] ? ? ? ?
x[1] ? ? ? ?
x[2] * ? ? ?
x[3] (+) X X X
* = thing to try next
X = ruled out
x[2] + x[0]
是负数,所以 x[1] + x[0]
不可能更好。接下来尝试 x[2] + x[1]
。
x[0] x[1] x[2] x[3]
x[0] X ? ? ?
x[1] X ? ? ?
x[2] (-) * ? ?
x[3] (+) X X X
x[2] + x[1]
是负数,所以 x[1] + x[1]
不能更好了。接下来尝试 x[2] + x[2]
。
x[0] x[1] x[2] x[3]
x[0] X X ? ?
x[1] X X ? ?
x[2] (-) (-) * ?
x[3] (+) X X X
...等等。
关于algorithm - 如何证明以下代码的正确性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26980969/
我有一个 const 方法,我想在其中将类 B 的一个成员的属性设置为当前实例 A(通过指针进行反向引用) A 类: void A::foo () const { ... ... B
Cython 生成的代码是否总是与生成它的 Python 代码一样正确? 它可能会帮助其他读者解决 Cython 静态类型声明和其他 Cython 功能(如果有的话)的使用问题,尽管我只对通过将 Py
我有一个包含一些指针的结构。我希望这些值是不可修改的。但是简单地写 const infront 并不能使结构成员不可变 typedef struct{ int *x; int *y; }poi
我需要评估和比较QR Code生成库,并寻找逻辑参数来测量和比较输出。 Why do I need this? It seems that when I give two different QR g
错误:Invalid conversion from 'char**' to 'const char**' 类似的问题似乎没有相同的情况(即两个函数在同一结构上具有不同的 const 要求)。如果确实
我确定以前有人问过这个问题,但所有搜索结果都有 const& 问题。 我想确保下面的方法不会改变传递给它的 GuestNode,所以我想传递 const GuestNode& guest,但是 g++
我有一个配置文件,它在我的程序运行时开始时被读入、解析并放入结构中。 我遇到的问题是我希望这些结构保持不变,因为它们中的值在程序生命周期内不应更改。 目前我正在做以下事情: 配置.h #pragma
我必须生成泊松分布的数据。我的范围是 n = 1000 到 100K。其中n是数据元素的数量; k 从 1 到 n 变化。它说使用 lambda 作为 n/2 我从未进行过统计,也不知道如何在这里获得
“如果每个顶点都可以从其他每个顶点到达,则称有向图是强连通的”。 Coreman 中给出的算法如下:- STRONGLY-CONNECTED-COMPONENTS (G) 1. Call DFS(G
我有一些代码是在不考虑 const 正确性的情况下编写的。有什么情况可以改变这个 class X { public: X(X& rhs); // does not modify rhs
我正在尝试对真正为 const 的类进行 const 操作 - 它不会更改该类指向的数据。 例如: class Node{ public: int val; }; class V{ publi
我没想到这段代码可以编译: #include #include class A { public: inline int get() const { return
将类的const 正确性 扩展到其指定成员的正确方法是什么?在示例代码中,get 方法的常量版本是否会创建一个 std::shared_ptr,其引用计数器与内部成员 m_b 相同,还是它重新从 0
我试图更好地理解 const-correctness 是如何工作的,更具体地说,在处理其成员基于 containers 和 smart pointers 的类时。我想无论类成员如何,const-cor
我有一个自定义迭代器实现(它迭代数据库查询结果,但这与此无关)。它在概念上有两组函数:get 类型函数,它从当前项目(当前行)返回一个值,以及 setup 类型函数(在我的例子中是 binds),它在
我目前面临一个由一些高级程序员编写的 C++ 项目,其中包含大约 400 个文件和 200 个类。 代码精心设计,运行良好且稳定。 虽然我正在添加一些功能,但对我来说,注意 const 的正确性只是普
这个问题在这里已经有了答案: What is the type of string literals in C and C++? (4 个回答) 关闭9年前。 根据 C++ 标准,字符串字面量类型是
我在一个类中有几个容器,例如 vector 或 map ,其中包含shared_ptr 指向堆上的对象。 例如 template class MyExample { public: private:
我知道很少有关于 const 正确性的问题,其中声明函数的声明及其定义不需要就值参数达成一致。这是因为值参数的常量只在函数内部很重要。这很好: // header int func(int i); /
对于本质上是只读但具有可能需要修改的互斥锁/锁的方法是否为 const 是否有约定? 如果没有,如果这种方法是 const 会有什么缺点/不好的设计 谢谢 最佳答案 您可以使用关键字mutable标记
我是一名优秀的程序员,十分优秀!