- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
给定一个由N个整数组成的非空数组A。数组 A 表示磁带上的数字。
任何整数 P,使得 0 < P < N,将此磁带分成两个非空部分:A[0]、A[1]、...、A[P − 1] 和 A[P] , A[P + 1], ..., A[N − 1].
两部分的区别在于:|(A[0] + A[1] + ... + A[P − 1]) − (A[P] + A[P + 1] + ... + A[N − 1])|
换句话说,就是第一部分之和与第二部分之和的绝对差。
例如,考虑这样的数组 A:
A[0] = 3
A[1] = 1
A[2] = 2
A[3] = 4
A[4] = 3
我们可以把这个磁带分成四个地方:
P = 1, difference = |3 − 10| = 7
P = 2, difference = |4 − 9| = 5
P = 3, difference = |6 − 7| = 1
P = 4, difference = |10 − 3| = 7
写一个函数:
class Solution { public int solution(int[] A); }
给定一个包含 N 个整数的非空数组 A,返回可以达到的最小差异。
例如,给定:
A[0] = 3
A[1] = 1
A[2] = 2
A[3] = 4
A[4] = 3
函数应该返回 1,如上所述。
为以下假设编写一个有效的算法:
N为[2..100,000]范围内的整数;数组 A 的每个元素都是 [−1,000..1,000] 范围内的整数。
针对上述问题,我尝试了以下方法,
int firstSum = 0;
int secondSum = 0;
int tot = Integer.MAX_VALUE;
List<Integer> col = new ArrayList<>();
int k=0;
while(m<A.length)
{
firstSum = firstSum + A[k];
for(int i=m; i<A.length; i++)
{
secondSum = secondSum + A[i];
}
k++;
}
System.out.println("Min DIfference: " +tot);
由于上述工作正常,但其时间复杂度达到 O(N*N)
,这是 Not Acceptable 。请帮助了解哪种算法适合这个问题。
最佳答案
可能是下面的方法可以帮助提高复杂性:
我会首先对元素进行累加和,即对于上面的示例:
int[] A = {3,1,2,4,3};
for(int i = 1; i< A.length; i++){
A[i] = A[i-1]+A[i];
}
生产:
[3, 4, 6, 10, 13]
并在第二个循环中计算总和的绝对差,总和位于索引 [A.length-1]
每个索引 i
|A[i] - (A[A.length-1] + A[i])|
您的方法可能类似于:
public static int solution(int[] A){
for(int i = 1; i< A.length; i++){
A[i] = A[i-1]+A[i];
}
System.out.println(Arrays.toString(A));
int min = Integer.MAX_VALUE;
for(int i = 0; i< A.length-1; i++){
if(Math.abs(A[i]-A[A.length-1]+A[i]) < min){
min = Math.abs(A[i]-A[A.length-1]+A[i]);
}
}
return min;
}
您还可以使用内置方法 Arrays.parallelPrefix(int[] array, IntBinaryOperator op)
来累加数组的元素并摆脱第一个循环。来自 javadoc
Cumulates, in parallel, each element of the given array in place, using the supplied function. For example if the array initially holds [2, 1, 0, 3] and the operation performs addition, then upon return the array holds [2, 3, 3, 6]. Parallel prefix computation is usually more efficient than sequential loops for large arrays.
代码使用Arrays.parallelPrefix
public static int solution(int[] A){
Arrays.parallelPrefix(A, Integer::sum);
System.out.println(Arrays.toString(A));
int min = Integer.MAX_VALUE;
for(int i = 0; i< A.length-1; i++){
if(Math.abs(A[i]-A[A.length-1]+A[i]) < min){
min = Math.abs(A[i]-A[A.length-1]+A[i]);
}
}
return min;
}
关于java - 找到数组中的绝对最小值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58622162/
我想要做的是在每个框的蓝色标题之后获取红色文本。 看来我必须添加另一个 div?我已经添加并修改了 .card-indus img 的位置,但结果永远不是我想要的。 你知道为什么即使我将 positi
所以我一直在努力掌握绝对和相对定位的诀窍。关于这个主题有很多教程和问题,我已尽力理解它们。除了这一点,我大部分时间都很好。我正在创建一个页面,其中有较小的缩略图图像,用户可以选择单击并展开图像。为此,
下面是我正在处理的代码。如您所见,有一个“#parent”div 和一个“#child”div。 '#child' div 有一个未定义的高度,这是因为有时,'#child' 的高度小于或长于它的父级
我目前正在创建一个看起来有点像这样的固定 header 。 https://gyazo.com/e0bab8ba195e33110b19123c7fc3c568 Logo 始终位于左侧,小按钮始终位于
我怎样才能得到一个绝对定位的子 div,当它放在父 div 的范围之外时不显示? https://jsfiddle.net/knp9ebys/9/ .papa { background:red;
如果我对 CSS 显得相当“菜鸟”,我深表歉意。我一直在尝试设置以下... #0 { width: 100%; height: y; border: 1px solid black; } #
很长一段时间以来,我一直在摆弄一个特定的布局问题,但我显然采用了错误的方式。 以下是分解为基本组成部分的方法: SOME HEADER
我创建了几个虚拟 Controller ,我希望能够从当前的 http 请求中获取 url。 例如: http://www.site.com/app_1/default.aspx ===> http:
我创建了几个虚拟 Controller ,我希望能够从当前的 http 请求中获取 url。 例如: http://www.site.com/app_1/default.aspx ===> http:
我想知道是否有一个库在某处提供受新类型保护的 FilePath 类型。我找到了我想要的http://hackage.haskell.org/package/darcs-2.8.4/docs/src/D
如果我尝试使用以下方式连接到我的嵌入式数据库: private static String url = "jdbc:sqlite:~/hr4413/pkg/sqlite/Models_R_US.db"
所以我是 django 的新手,我一直在研究 PHP CodeIgniter,其中将绝对 URL 放入 href 我通过调用 URL 帮助程序使用了一个名为 base_url 的函数 它给出的输出类
我有一个小问题。 我在其他 div 中有一些图像元素的容器 div。像这样的东西: 我需要将容器垂直居中,但我不能使用顶部:-healfHeight; mar
我有一个带有 inline-block css 位置的列表(div)。里面有一个 relative 定位的 ul 是隐藏的。所以我试图通过添加一些类将这个 div 转换为 absolute 。通常,当
我正在尝试设置一个卡住列,唯一需要解决的问题是同一行上其他 td 的高度不会扩展以匹配绝对定位 td 的高度。由于卡住标题中的文本是任意的,它可以跨越多行。 如果它不是绝对定位的,那么这将迫使同一行中
这个问题在这里已经有了答案: Centering text vertically and horizontally in a div (1 个回答) 关闭 5 年前。
当它的位置绝对时,我试图使一个框宽度为 100%? 下图是我想要做的 https://i.imgur.com/qMaT361.gif float .box1 { position:re
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and t
我有 3 个 div,都是 positioned: absolute,但是我想要填充窗口宽度的 div 只会适应其中文本的长度。我希望黄色 div #help 填充窗口的其余部分。 我知道这听起来很菜
这个问题在这里已经有了答案: Retrieve the position (X,Y) of an HTML element (32 个答案) 关闭 8 年前。 有时候,当我请求某个对象的.posit
我是一名优秀的程序员,十分优秀!