Embracing Algorithms
But there is a problem that if you try to delete 2 consecutive elements.
data:image/s3,"s3://crabby-images/3271e/3271e0317715db5517b806330ec582a815bedf04" alt=""
Final Bug fix
data:image/s3,"s3://crabby-images/436fc/436fc5de92eb115993ca8bafb0b4b3ae92f6b734" alt=""
Optimization
The remove(at: ) complexity is O(n)
data:image/s3,"s3://crabby-images/35d14/35d1462995c8d8846be85d348ae4911cb1214fab" alt=""
So the deleteSelection() complexity is O(n²)
data:image/s3,"s3://crabby-images/15f42/15f42561cd0882afa65cbf366cb9440fc0e826f9" alt=""
we can optimize the function O(n²) → O(n) by the removeAll(where: )
data:image/s3,"s3://crabby-images/8f94b/8f94be6e26df67fa5f29759a89b7f81dfc8a30db" alt=""
data:image/s3,"s3://crabby-images/90d1e/90d1e2651fb2ecc4a060a4063a8dff43b3c96525" alt=""
Linear vs Quadratic
Linear algorithms always wins
data:image/s3,"s3://crabby-images/94e19/94e193bbd37c861f51bd118192ebd8b482b2b747" alt=""
Problem 2
data:image/s3,"s3://crabby-images/3d6b0/3d6b075c7e39ec10196429fb0fb23a5569db3aa3" alt=""
data:image/s3,"s3://crabby-images/74637/74637193cde82641ce436ec194f47674c424556c" alt=""
Optimization
O(n²) → O(n)
data:image/s3,"s3://crabby-images/7ddca/7ddca7bdc9a8e3628cf93fd601d3c0d1d159b099" alt=""
Problem 3
data:image/s3,"s3://crabby-images/8c65a/8c65a438a56237585b0c99ce04deba6283a1b950" alt=""
Optimization
data:image/s3,"s3://crabby-images/e10dd/e10dd6f4738cbf2ba3f381578a5ec83533b40ab6" alt=""
data:image/s3,"s3://crabby-images/ee8c2/ee8c2b4f63f641c18afb66284c81ee76a78d5ea0" alt=""
Problem 4
data:image/s3,"s3://crabby-images/ce894/ce894eeaefa4d5ab6a5dd690cdaeb5faf323ae9a" alt=""
Optimization
data:image/s3,"s3://crabby-images/45e0d/45e0de3ba8825691c56d92c28a0dba6995fec3b1" alt=""