- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这是 Codility 的三角问题:
A zero-indexed array A consisting of N integers is given.
A triplet (P, Q, R) is triangular if 0 ≤ P < Q < R < N and:A[P] + A[Q] > A[R],
A[Q] + A[R] > A[P],
A[R] + A[P] > A[Q].Write a function:
int solution(vector<int> &A);
that, given a zero-indexed array A consisting of N integers, returns 1 if there exists a triangular triplet for this array and returns 0 otherwise.
For example, given array A such that:
A[0] = 10, A[1] = 2, A[2] = 5, A[3] = 1, A[4] = 8, A[5] = 20 Triplet (0, 2, 4) is triangular, the function should return 1.Given array A such that:
A[0] = 10, A[1] = 50, A[2] = 5, A[3] = 1
function should return 0.Assume that:
N is an integer within the range [0..100,000];
each element of array A is an integer within the range [−2,147,483,648..2,147,483,647].
这是我在 C++ 中的解决方案:
int solution(vector<int> &A) {
if(A.size()<3) return 0;
sort(A.begin(), A.end());
for(int i=0; i<A.size()-2; i++){
//if(A[i] = A[i+1] = A[i+2]) return 1;
if(A[i]+A[i+1]>A[i+2] && A[i+1]+A[i+2]>A[i] && A[i+2]+A[i]>A[i+1]){
return 1;
}
}
return 0;
}
我查看了那里的评论,所有的解决方案似乎都与我的相似。
然而,别人都说100分,我却只有93分。
我得到了所有的测试用例,除了一个:
extreme_arith_overflow1
overflow test, 3 MAXINTs
我假设这个案例有这样的输入:
[2147483647, 2147483647, 2147483647]
所以我将其添加到自定义测试用例中,结果明明应为 1 时答案却为 0。
我也试了[1900000000, 1900000000, 1900000000],答案还是0。
但是,[1000000000, 1000000000, 1000000000] 是正确的,答案为 1。
谁能告诉我为什么会出现这个结果?
非常感谢。
最佳答案
我的 Java 解决方案具有 100/100 和 O(N*log(N)) 的时间复杂度
注释说明逻辑
// you can also use imports, for example:
// import java.util.*;
// you can write to stdout for debugging purposes, e.g.
// System.out.println("this is a debug message");
import java.util.Arrays;
class Solution {
public int solution(int[] A) {
int N = A.length;
if (N < 3) return 0;
Arrays.sort(A);
for (int i = 0; i < N - 2; i++) {
/**
* Since the array is sorted A[i + 2] is always greater or equal to previous values
* So A[i + 2] + A[i] > A[i + 1] ALWAYS
* As well ass A[i + 2] + A[i + 1] > A[i] ALWAYS
* Therefore no need to check those. We only need to check if A[i] + A[i + 1] > A[i + 2]?
* Since in case of A[i] + A[i + 1] > MAXINT the code would strike an overflow (ie the result will be greater than allowed integer limit)
* We'll modify the formula to an equivalent A[i] > A[i + 2] - A[i + 1]
* And inspect it there
*/
if (A[i] >= 0 && A[i] > A[i + 2] - A[i + 1]) {
return 1;
}
}
return 0;
}
基本上,当您检查整数的 X + Y
值时,如果大于整数限制,代码将因溢出而失败。因此,我们可以简单地检查等效语句 if X > Z - Y
,而不是检查 if X + Y > Z
(简单的数学不是吗?)。或者,您始终可以使用 long
,但这在内存方面会是一个更糟糕的解决方案。
还要确保跳过负数,因为三角形不能有负边值。
干杯
关于c++ - 三角形 : Determine if an array includes a triangular triplet (Codility),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44912099/
我发现很难提出问题,但我想找到一种聪明的方法(不使用循环)来获得以下结果: > my.vector = letters[1:6] > print(my.vector) [1] "a" "b" "c"
我如何转换这种类型: std::tuple 进入这个: std::tuple, std::function, std::function, ... std::function > 最佳
我很难在 SQL 中得到一个 - 看似简单 - 的权利。我正在使用 MS Access,但我想这并不重要。 我的数据结构如下所示: 所以tblA有“产品”,tblB “组件”和tblC “模块”。这显
我想要将一组子图分为三行,第一行有一个子图,第二行有两个,第三行有三个。我做了以下事情: fig, axes = plt.subplots(figsize=(10, 10), sharex=True,
我正在尝试创建悬停菜单。将其悬停在菜单项中会出现一个三 Angular 形。但是当我进入下拉菜单时,它就消失了。 .navbar-wrapper .col-lg-8 ul li a:hover{
这仅涉及多边形面(具有超过 4 条边的对象面).. 在 3DSMAX 中,.OBJ 有 3 种导出模式:三 Angular 形、四边形和多边形。我已经进行了多次测试,并使用两个可用的工作流程(使用 O
我正在尝试创建一个直 Angular 三棱柱。 到目前为止,这是我的代码: var triangleGeometry = new THREE.Geometry(); triangleGeometry.
我想运行一个模拟,该模拟使用下限 A、模式 B 和上限 C 的三角概率分布生成的值作为参数。如何在 Python 中生成该值?对于这个分布,是否有像 expovariate(lambda)(来自随机)
我正在尝试使用 DAC 和 DMA 生成频率为 8kHz 的三角波。使用定时器触发 DAC,以便 DAC 速度为 1 MSPS。我正在研究 stm32L476 发现板。我使用 stm32CUBEMX
Project Euler problem 18要求我们找到三角形网格中从上到下总和最大的路线。 我的程序应该能够接受如下所示的输入。测试用例的数量 (2) 出现在第一行,然后对于每个测试用例给出行数
这是 Codility 的三角问题: A zero-indexed array A consisting of N integers is given. A triplet (P, Q, R) is
我正在添加一个新函数,如果它是上三角形,则将 DataFrame 转换为下三角形,反之亦然。我使用的数据总是有前两行只用第一个索引填充。 我尝试使用这个问题的解决方案 Pandas: convert
编辑: 这个问题已经解决了。如果您想帮助解决其他问题,请访问 Java Biasing Random Numbers in a Triangular Array . 我在玩乘法游戏,所以我选择了 0
我主要使用 Armadillo 来处理对称矩阵和三角形矩阵。我希望在内存存储方面保持高效。然而,似乎没有其他方法,只能创建一个新的垫子并用零(对于三角形)或重复项(对于对称)填充矩阵的下/上部分。 是
我正在编写一些操纵 3D 三角形网格的代码。导入网格数据后,我需要“统一”空间中同一点的顶点。 我一直假设 numpy 数组是存储和操作数据的最快方式,但我似乎无法找到一种既能快速构建顶点列表又能避免
我是一名优秀的程序员,十分优秀!