- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个简单的自定义对象数组。
我想将数组缩减为按最大尺寸选择的每种颜色的一个实例。
我想出的解决方案似乎很笨重,什么是最好的方法,我已经尝试查看 reduce 和 filter 但无法弄清楚如何在此处应用。
class foo {
var color: String
var size: Int
var shape: String
init(color:String, size:Int, shape:String){
self.color = color
self.size = size
self.shape = shape
}
}
var array = [foo]()
array.append(foo(color: "Blue", size: 2, shape: "Round"))
array.append(foo(color: "Red", size: 3, shape: "Square"))
array.append(foo(color: "Blue", size: 5, shape: "Round"))
array.append(foo(color: "Yellow", size: 1, shape: "Triangle"))
array.append(foo(color: "Blue", size: 1, shape: "Hexagon"))
最佳答案
您可以通过首先对数组进行排序,然后使用例如过滤掉重复的颜色对象来避免暴力 O(n^2)
嵌套循环(和枚举)解决方案哈希值查找(下面的方法 1)或针对排序数组的巧妙排除(下面的方法 2)。
另请注意类 type 命名约定(CamelCase
):因此 Foo
而不是 foo
。
免责声明:不要对下面的渐近复杂性符号视而不见,如 premature optimization根据程序的上下文和预期使用区域,这通常是一种罪过。我将它们包含在下面只是为了有一些措施来比较不同的方法。选择您认为最有意义的一项。
方法一
Worst case...
time complexity:
O(n log n)
space complexity:
O(n)
Where space complexity refers to space used in excess of the array to which the final result is assigned.
Foo
符合Hashable
(让hashValue
与.color
属性相关)。Foo
实例 w.r.t 的数组进行排序。减小尺寸(.size
属性)。Hashable
的一致性来快速使用 O(1)
散列值查找 Foo:Bool
中的现有颜色> 词典。改编自 Airspeed Velocity 在 the following answer 中的评论.方法 2(由 Nikolai Ruhe 提出):
Worst case...
time complexity:
O(n log n)
space complexity:
O(1)
对于第三种(可能是该应用程序的最佳方法)方法,see Nikolai Ruhe:s answer below , 分别提出了一个 O(n)
/O(n)
时间/空间最坏情况复杂度的方法。
实现
[只有方法 1 需要此步骤] 使 Foo
符合 Hashable
和 Equatable
:
/* Let Foo conform to Hashable */
class Foo : Hashable {
var color: String
var size: Int
var shape: String
init(color:String, size:Int, shape:String){
self.color = color
self.size = size
self.shape = shape
}
var hashValue: Int {
return color.hashValue
}
}
/* And Equatable */
func ==(lhs: Foo, rhs: Foo) -> Bool {
return lhs.color == rhs.color
}
下面是过滤器方法的设置和示例:
/* Foo array example */
var array = [Foo]()
array.append(Foo(color: "Blue", size: 2, shape: "Round"))
array.append(Foo(color: "Red", size: 3, shape: "Square"))
array.append(Foo(color: "Blue", size: 5, shape: "Round"))
array.append(Foo(color: "Yellow", size: 1, shape: "Triangle"))
array.append(Foo(color: "Blue", size: 1, shape: "Hexagon"))
根据您的规范过滤:
/* Method 1 (assumes Foo conforms to Hashable (& Equatable)) */
var addedDict = [Foo:Bool]()
var arrFiltered = array.sort{ $0.0.size > $0.1.size }
.filter {addedDict.updateValue(true, forKey: $0) == nil }
/* Method 2 (as proposed by Nikolai Ruhe) */
var previousColor: String?
let arrFiltered = array.sort{ $0.color == $1.color ? $0.size > $1.size : $0.color < $1.color }
.filter{ if $0.color != previousColor { previousColor = $0.color; return true }; return false }
/* condensed .filter solution by @Nikolai Ruhe, thanks! */
结果:
for bar in arrFiltered {
print(bar.color, bar.size)
}
/* Blue 5
Red 3
Yellow 1 */
排序步骤是此解决方案中的主要步骤(对于这两种方法)。来自 swift/stdlib/public/core/Sort.swift.gyb ,似乎 Swift 使用了 introsort (特别是 introsort 与 insertion sort 的混合体),在最坏情况下运行为 O(n log n)
。
关于arrays - 按规则减少数组中对象的实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35265374/
在 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() {
我是一名优秀的程序员,十分优秀!