From: Raymond Hettinger Date: Mon, 4 Sep 2017 18:47:58 +0000 (-0700) Subject: Improve clarity (and small speed-up) by using tuple unpacking (#3289) X-Git-Tag: v3.7.0a1~180 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1bfbe78b03e6ee3ee7de938b5e39015dd08b0302;p=python Improve clarity (and small speed-up) by using tuple unpacking (#3289) --- diff --git a/Lib/heapq.py b/Lib/heapq.py index 0b3e89a3a9..b31f4186cf 100644 --- a/Lib/heapq.py +++ b/Lib/heapq.py @@ -498,10 +498,10 @@ def nsmallest(n, iterable, key=None): for elem in it: if elem < top: _heapreplace(result, (elem, order)) - top = result[0][0] + top, _order = result[0] order += 1 result.sort() - return [r[0] for r in result] + return [elem for (elem, order) in result] # General case, slowest method it = iter(iterable) @@ -516,10 +516,10 @@ def nsmallest(n, iterable, key=None): k = key(elem) if k < top: _heapreplace(result, (k, order, elem)) - top = result[0][0] + top, _order, _elem = result[0] order += 1 result.sort() - return [r[2] for r in result] + return [elem for (k, order, elem) in result] def nlargest(n, iterable, key=None): """Find the n largest elements in a dataset. @@ -559,10 +559,10 @@ def nlargest(n, iterable, key=None): for elem in it: if top < elem: _heapreplace(result, (elem, order)) - top = result[0][0] + top, _order = result[0] order -= 1 result.sort(reverse=True) - return [r[0] for r in result] + return [elem for (elem, order) in result] # General case, slowest method it = iter(iterable) @@ -577,10 +577,10 @@ def nlargest(n, iterable, key=None): k = key(elem) if top < k: _heapreplace(result, (k, order, elem)) - top = result[0][0] + top, _order, _elem = result[0] order -= 1 result.sort(reverse=True) - return [r[2] for r in result] + return [elem for (k, order, elem) in result] # If available, use C implementation try: