【问题标题】:Building an index from an attribute从属性构建索引
【发布时间】:2016-02-21 02:50:21
【问题描述】:

我有一个简单的聚会课程

class Meetup {
  var title: String
  var date: String
}

还有一组从 meetup.com 获取的名为 meetups 的聚会。

我想在字典中按日期组织这些聚会:[String, [Meetup]],其中字符串是日期。

这是我的实现

func buildDateMeetupDict(meetups: [Meetup]) -> [String, [Meetup]] {

    var dateMeetupDict = [String: [Meetup]]()

    for meetup in meetups {
        for var meetupsByDay in dateMeetupDict {
            if meetupsByDay.day == meetup.day {
                meetupsByDay.meetupArray.append(meetup)
            } else {
                let newMeetupDay = [meetup.day, [meetup]]
                dateMeetupDict.append(newMeetupDay)
            }
        }
    }
    return dateMeetupDict
}

它有效,但效率极低,感觉和看起来都像贫民窟。

如何有效地从数组中的对象中提取属性并基于该属性构建索引?

【问题讨论】:

  • 你的字典在哪里? [String, [Meetup]]() 不是字典(我真的不知道它是什么;我很惊讶它能编译)。
  • “但效率极低” 怎么会这样?这显然是一个很好的方法。有什么问题?
  • @matt 你说得对,有一个错字。
  • 不要输入。复制粘贴!
  • @matt 问题是感觉不对。我在想也许有更好的实践方法,有一些我会忘记的更相关的语言特性。 (回答第二条评论——将复制+粘贴 fno)

标签: ios swift loops dictionary data-structures


【解决方案1】:

我会按照你的做法去做。毕竟,您只在数组中循环一次。

我想你可能想更清楚地表达算法。您对每个聚会的选择是:

  • 如果该键不存在,则创建它并将其值设为包含此 Meetup 的数组;

  • 如果键确实存在,则将此聚会附加到其值数组中。

我想我们可以很直白地说,如下:

// here's a test class
// [Note: I used `id` instead of `date`, but it's still just a string...]
class Meetup : CustomStringConvertible {
    var id: String
    var title: String
    init(id:String, title:String) {
        self.id = id; self.title = title
    }
    var description: String {
        return "\(self.id)/\(self.title)"
    }
}

// here's a test array of Meetups
let meetups : [Meetup] = [
    Meetup(id:"one", title:"Howdy"),
    Meetup(id:"two", title:"Hello"),
    Meetup(id:"two", title:"Bonjour"),
    Meetup(id:"one", title:"Namaste")
]

// and here's our actual code!
var dict = [String:[Meetup]]()
for meetup in meetups {
    let val = dict[meetup.id]
    dict[meetup.id] = val == nil ? [meetup] : val! + [meetup]
}

现在让我们证明它有效:

print(dict) // ["one": [one/Howdy, one/Namaste], "two": [two/Hello, two/Bonjour]]

所以我们最终得到了一个字典,它的键是原始的 ids(你的日期),每个 id 的值是带有 id 的 Meetups 数组。

【讨论】:

  • 是的,这就是我要说的!我用谷歌搜索这部分是如何工作的dict[meetup.id] = val == nil ? [meetup] : val! + [meetup]
  • 或者等等这只是 nil 合并运算符的偷偷摸摸的实现??
  • @EricJohnson 你知道?:“三元”运算符吗? apeth.com/swiftBook/ch05.html#_conditional_evaluation
  • 大致做到了,但现在我做到了。这也是dict[meetup.id] = val == nil 说“将val 分配给dict[meetup.id] 并将其与nil 进行比较”?
  • 没有。整行说:“如果val 为零,则将[meetup] 分配给dict[meetup.id]。如果val 不为零,则将val! + [meetup] 分配给dict[meetup.id]
猜你喜欢
  • 1970-01-01
  • 2016-09-14
  • 1970-01-01
  • 2022-12-29
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-06-16
相关资源
最近更新 更多