From ff08b723dbb66fc9336dffe7fef4c09f55a07a5b Mon Sep 17 00:00:00 2001 From: William Carroll Date: Mon, 16 Nov 2020 17:12:05 +0000 Subject: Solve "find pairs for sum" I have encountered this problem 3x in the wild thus far: 1. www.InterviewCake.com 2. Cracking the Coding Interview 3. www.Pramp.com --- scratch/facebook/moderate/find-pairs-for-sum.py | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) create mode 100644 scratch/facebook/moderate/find-pairs-for-sum.py diff --git a/scratch/facebook/moderate/find-pairs-for-sum.py b/scratch/facebook/moderate/find-pairs-for-sum.py new file mode 100644 index 000000000000..69c2fc431296 --- /dev/null +++ b/scratch/facebook/moderate/find-pairs-for-sum.py @@ -0,0 +1,19 @@ +import random + +def find_pairs(xs, n): + """ + Return all pairs of integers in `xs` that sum to `n`. + """ + seeking = set() + result = set() + for x in xs: + if x in seeking: + result.add((n - x, x)) + else: + seeking.add(n - x) + return result + +xs = [random.randint(1, 10) for _ in range(10)] +n = random.randint(1, 10) + random.randint(1, 10) +print("Seeking all pairs in {} for {}...".format(xs, n)) +print(find_pairs(xs, n)) -- cgit 1.4.1