Tag: 迭代器

调用在Java中的foreach循环中删除

在Java中,使用foreach循环遍历集合时调用集合上的remove是否合法? 例如: List<String> names = …. for (String name : names) { // Do something names.remove(name). } 作为附录,删除尚未被迭代的项目是否合法? 例如, //Assume that the names list as duplicate entries List<String> names = …. for (String name : names) { // Do something while (names.remove(name)); }

迭代时修改列表

l = range(100) for i in l: print i, print l.pop(0), print l.pop(0) 上面的python代码给出了与预期完全不同的输出。 我想循环的项目,以便我可以跳过一个项目,而循环。 请解释。

构build一个基本的Python迭代器

如何在Python中创build一个迭代函数(或迭代器对象)?

Python的迭代器,迭代器和迭代协议究竟是什么?

Python中“iterable”,“iterator”和“iteration”的最基本定义是什么? 我已经阅读了多个定义,但是它们的确切含义仍然不会消失。 有人可以帮助我的基本思路?

如何并行迭代两个列表?

我在Python中有两个iterables,我想成对地去看看它们: foo = (1, 2, 3) bar = (4, 5, 6) for (f, b) in some_iterator(foo, bar): print "f: ", f, "; b: ", b 它应该导致: f: 1; b: 4 f: 2; b: 5 f: 3; b: 6 一种方法是迭代索引: for i in xrange(len(foo)): print "f: ", foo[i], "; b: ", b[i] 但是这对我来说似乎有些不合理。 有没有更好的方法来做到这一点?

“yield”关键字有什么作用?

Python中yield关键字的用法是什么? 它有什么作用? 例如,我试图理解这个代码1 : def _get_child_candidates(self, distance, min_dist, max_dist): if self._leftchild and distance – max_dist < self._median: yield self._leftchild if self._rightchild and distance + max_dist >= self._median: yield self._rightchild 这是来电者: result, candidates = list(), [self] while candidates: node = candidates.pop() distance = node._get_dist(obj) if distance <= max_dist and distance >= min_dist: result.extend(node._values) candidates.extend(node._get_child_candidates(distance, min_dist, max_dist)) […]

zip(* * n)在Python中如何工作?

s = [1,2,3,4,5,6,7,8,9] n = 3 zip(*[iter(s)]*n) # returns [(1,2,3),(4,5,6),(7,8,9)] zip(*[iter(s)]*n)工作? 如果使用更详细的代码编写,它会是什么样子?