1 |
1. T : Type
2. L1 : T List
3. L2 : T List
4. L : T List
5. x : T
6. i,j: . i<||L|| data:image/s3,"s3://crabby-images/29e0d/29e0d7d64cba60b98412516f837d2b91fd856b1e" alt="" j<||L|| data:image/s3,"s3://crabby-images/29e0d/29e0d7d64cba60b98412516f837d2b91fd856b1e" alt="" i = j data:image/s3,"s3://crabby-images/29e0d/29e0d7d64cba60b98412516f837d2b91fd856b1e" alt="" L[i] = L[j]
7. f1 : ||L1 @ [x]||data:image/s3,"s3://crabby-images/f3541/f3541d344070c024f666f7857c8dc6089540b82c" alt="" data:image/s3,"s3://crabby-images/bb3b1/bb3b1d0ea2548f59ee96a19f20c52f447be14c28" alt="" ||L||
8. increasing(f1;||L1 @ [x]||)
9. j: ||L1 @ [x]||. (L1 @ [x])[j] = L[(f1(j))]
10. f : (||L2||+1)data:image/s3,"s3://crabby-images/f3541/f3541d344070c024f666f7857c8dc6089540b82c" alt="" data:image/s3,"s3://crabby-images/bb3b1/bb3b1d0ea2548f59ee96a19f20c52f447be14c28" alt="" ||L||
11. increasing(f;||L2||+1)
12. j: (||L2||+1). [x / L2][j] = L[(f(j))]
f:( ||L1 @ [x / L2]||data:image/s3,"s3://crabby-images/f3541/f3541d344070c024f666f7857c8dc6089540b82c" alt="" data:image/s3,"s3://crabby-images/bb3b1/bb3b1d0ea2548f59ee96a19f20c52f447be14c28" alt="" ||L||).
increasing(f;||L1 @ [x / L2]||)
& ( j: ||L1 @ [x / L2]||. (L1 @ [x / L2])[j] = L[(f(j))])
data:image/s3,"s3://crabby-images/0e753/0e7530d6bceafb511dae5fb4067d8ce90271ff7f" alt="" | 40 steps |