→ uranusjr: 簡單的方法是把 list_a 的 index 用 dict cache 起來 02/27 16:03
→ uranusjr: 每個 b 裡的值都要在 a 從頭找一次當然會慢 02/27 16:03
→ CaptPlanet: 感恩 已解決 02/27 16:21
推 Yshuan: 做一個 dict([(v, i) for i, v in enumerate(list_a)]) 02/27 16:51
→ Yshuan: 用空間換取時間這樣... 02/27 16:51
推 Yshuan: res_li = map(lambda k: new_dict.get(k, ""), list_b) 02/27 16:54
推 thefomalhaut: cython or numpy? 02/28 00:53
→ secondsee: 或可用set找出交集, 直接拿去list_a比對 02/28 10:36
→ secondsee: check = set(list_a) & set(list_b) 02/28 10:41
→ secondsee: res_li = [i for i,x in enumerate(a) if x in check] 02/28 10:43
推 vfgce: 樓上的解法有誤...也沒有比dict快. 02/28 11:58
推 vfgce: Y大解法ok,只是map回傳的是iterator,再轉成list似乎沒有 02/28 12:03
→ vfgce: 比直接用list comprehension快. 02/28 12:04
推 eggeggss: 2個list轉set後intersection再產生新的list 10/27 16:42