- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
如问题中所述,需要找到数组中 (i,j) 对的总数,使得
(1) **i<j**
(2) **a[i]>a[j]**
其中 i 和 j 是数组的索引。没有空间限制。
我的问题是
1) Is there any approach which takes less than O(N^2) time?
2) if so what is least complexity ?
3) How do we prove that ?
我希望我对这个问题很清楚。
我的做法如下
做这道题的一种方法是使用暴力破解,这需要 O(N^2) 时间。
但我认为这个问题应该有一个更好的优化解决方案——至少O(NlogN)的解决方案。我的直觉原因如下
直觉 1) For sorting an array in ascending order conditions we have are : for i<j , a[i]<a[j] which is similar to my question . I also read that sorting has lower bound of Omega(n log n) . So my question should also have Omega(n log n) . I may be completely wrong if so please correct me .
我的第二个直觉是:
假设我们有一个元素数组如下:4,9,7,3,2,1,8,12
我们计算以上条件i<j , a[i]>a[j]
对于元素 4 ,当 i=0 指向 4 时,j 的可能值为 3,4,5 。因为 a[0]>a[3],a[0]>a[4],a[0]> a[5] ,所以我现在的 (i,j) 对总数是 3 。 下次当我将 i(index) 增加到 1 时,j 的可能值为 2,3,4,5,6 。但是我们应该使用这样一个事实,即当 i=0(当 a[i]=4)时,我们计算了 3 个小于 a[i=0] 的元素,而 a[i=0] 又小于 a[i=1],所以我不会将 9 与 3,2,1 进行比较(删除不必要的计算)。如果我们可以删除不必要的计算,那么我们可以将复杂性降低到小于 O(N^2) 的程度,否则不存在小于 O(N^2) 的解决方案。但如果存在解决方案,那么我们该怎么做。我尝试制作图表,但我的努力是徒劳的。
方法 1) In-order to obtain O(nlogn) complexity I think we need to tweak around quick sort or merge sort to get solution but problem here is, if we sort the array we loose the actual positions of elements.
方法 2)In-order to get solution in O(NlogN) time I think using tree we may get the optimised sollution . I didn't get any clue.
方法 3) If there exists any O(N) time algorithm it should be with hashing . But in this case simple hashing doest work .
所以请让我知道以上哪些直觉或方法是正确的(如果正确,哪种方法将导致优化的解决方案以及如何)。
最佳答案
您可以使用该算法计算反向对,类似于归并排序,如解释的那样 here .
想法是在计数的同时对数组进行归并排序,每一步改变了多少次反转。
另一种方法是使用订单统计树。您按顺序将数组的元素插入到这棵树中,并在每次插入后查看插入元素之前有多少元素大于它。
订单统计树的替代方法是 Indexable skiplist .
两种算法的时间复杂度均为 O(N log N)。
要获得近似的反转次数,O(N) 时间复杂度是可能的,但有一些限制。我们可以修改Bucket sort以相同的方式修改合并排序。
在桶排序的“分散”阶段,我们应该为较大的元素估计桶中元素的数量,同时在某个桶的末尾插入元素(每个桶中的元素保持原始顺序)。
在桶排序的“排序”阶段,我们应该修改(以相同的方式)排序算法(最有可能是插入排序)。在将元素插入到适当的位置时,我们应该计算它跳过了多少其他元素。
至于局限性,该算法仅适用于数字(或对象,易于转换为数字),我们应该提前知道这些数字是如何分布的。所以,如果我们有一个均匀分布的整数数组,这个算法应该可以正常工作。
关于arrays - 找出数组中满足 i<j 和 a[i]>a[j] 的 (i,j) 对的总数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13158439/
在 C 中: int a[10]; printf("%p\n", a); printf("%p\n", &a[0]); 产量: 0x7fff5606c600 0x7fff5606c600 这是我所期望
我一直在尝试运行此循环来更改基于数组的元素的位置,但出现以下错误。不太确定哪里出了问题。任何想法或想法!谢谢。 var population = [[98, 8, 45, 34, 56], [9, 1
我正在尝试获取一个 Ruby 数组数组并将其分组以计算其值。 数组有一个月份和一个 bool 值: array = [["June", false], ["June", false], ["June"
所以我们的目标是在遇到某个元素时将数组分割成子数组下面的示例 array.split("stop here") ["haii", "keep", "these in the same array bu
在this问题已经回答了两个表达式是相等的,但在这种情况下它们会产生不同的结果。对于给定的 int[] 分数,为什么会这样: Arrays.stream(scores) .forEac
我认为我需要的是哈希数组的数组,但我不知道如何制作它。 Perl 能做到吗? 如果是这样,代码会是什么样子? 最佳答案 perldoc perldsc是了解 Perl 数据结构的好文档。 关于arra
我遇到了这个问题,从 API 中我得到一个扩展 JSON,其中包含一个名为坐标的对象,该对象是一个包含数组 o 数组的数组。 为了更清楚地看这个例子: "coordinates": [
postgres 中有(v 9.5,如果重要的话): create table json_test( id varchar NOT NULL, data jsonb NOT NULL, PRIM
我用 echo "${array[@]}" 和 echo "${array[*]}" 得到了相同的结果。 如果我这样做: mkdir 假音乐; touch fakemusic/{Beatles,Sto
我正在尝试创建 typealias 对象的数组数组 - 但我收到“表达式类型不明确,没有更多上下文”编译错误。这是我的代码: typealias TestClosure = ((message: St
如果您在 Python 中创建一维数组,使用 NumPy 包有什么好处吗? 最佳答案 这完全取决于您打算如何处理数组。如果您所做的只是创建简单数据类型的数组并进行 I/O,array模块就可以了。 另
当我将数组推送到只有一个数组作为其唯一元素的数组数组时,为什么会得到这种数据结构? use v6; my @d = ( [ 1 .. 3 ] ); @d.push( [ 4 .. 6 ] ); @d.
在 Julia 中,我想将定义为二维数组向量的数据转换为二维矩阵数组。 如下例所述,我想把数据s转换成数据t,但是至今没有成功。 我该如何处理这个案子? julia> s = [[1 2 3], [4
C 没有elementsof 关键字来获取数组的元素数。所以这通常由计算 sizeof(Array)/sizeof(Array[0]) 代替但这需要重复数组变量名。1[&Array] 是指向数组后第一
所以,假设我有一个像这样的(愚蠢的)函数: function doSomething(input: number|string): boolean { if (input === 42 || in
我有以下数组: a = [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16] 我将它用于一些像这样的视觉内容: 1 2 3 4 5 6 7 8 9 10
我想知道数组中的 .toList 与 .to[List] 之间有什么区别。我在spark-shell中做了这个测试,结果没有区别,但我不知道用什么更好。任何意见? scala> val l = Arr
我很难获得完全相同对象的多个元素的当前元素索引: $b = "A","D","B","D","C","E","D","F" $b | ? { $_ -contains "D" } 替代版本: $b =
我正在尝试使用来自我的 API 的 v-select 执行 options,我将数据放在数组数组中。 Array which I got from API 它应该是一个带有搜索的 select,因为它
这个问题在这里已经有了答案: String literals: pointer vs. char array (1 个回答) 4 个月前关闭。 当我执行下一个代码时 int main() {
我是一名优秀的程序员,十分优秀!