Advertisement
Guest User

Untitled

a guest
Jan 24th, 2020
285
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Python 0.71 KB | None | 0 0
  1. def do_insertions_simple(l, insertions):
  2.     r = list(l)
  3.     for i, x in insertions:
  4.         r.insert(i, x)
  5.     return r
  6.  
  7.  
  8. def do_insertions_fast(l, insertions):
  9.     result = []
  10.     extended = 0
  11.     for appended, (idx, val) in enumerate(insertions):
  12.         if idx > len(result):
  13.             result.extend(l[extended : idx - appended])
  14.             extended += idx - appended - extended
  15.         result.append(val)
  16.     result.extend(l[extended:])
  17.     return result
  18.  
  19.  
  20. from random import randint
  21.  
  22. l = list(range(1_000_000))
  23. insertions = [(randint(0, len(l)), "x") for _ in range(10_000)]
  24. insertions.sort()
  25. r1 = do_insertions_simple(l, insertions)
  26. r2 = do_insertions_fast(l, insertions)
  27. assert r1 == r2
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement