Jump to content

Block swap algorithms: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Wl
Line 10: Line 10:
* Rotate region AB
* Rotate region AB


Gries-Mills and Reversal algorithms perform better than Bentley's Juggling, because of their [[Cache (computing)|cache]]-friendly memory access pattern behavior.
Gries-Mills and Reversal algorithms perform better than Bentley's Juggling, because of their [[Cache (computing)|cache]]-friendly [[memory access pattern]] behavior.


The Reversal algorithm [[Parallel computing|parallelizes]] well, because rotations can be split into sub-regions, which can be rotated independently of others.
The Reversal algorithm [[Parallel computing|parallelizes]] well, because rotations can be split into sub-regions, which can be rotated independently of others.

Revision as of 11:32, 5 August 2020

Block swap algorithms is the simple art of swapping two elements of an array in computer algorithms. It is also simple to swap two non-overlapping regions of an array of equal size. However, it is not simple to swap two non-overlapping regions of an array in-place that are next to each other, but are of unequal sizes. Three algorithms are known to accomplish this: Bentley's Juggling, Gries-Mills, and Reversal.[1] All three algorithms are linear time O(n), (see Time complexity).

Reversal algorithm

The reversal algorithm is the simplest to explain, using rotations. A rotation is an in-place reversal of array elements. This method swaps two elements of an array from outside in within a range. The rotation works for an even number of elements or an odd number of array elements. The reversal algorithm uses three in-place rotations to accomplish an in-place block swap:

  • Rotate region A
  • Rotate region B
  • Rotate region AB

Gries-Mills and Reversal algorithms perform better than Bentley's Juggling, because of their cache-friendly memory access pattern behavior.

The Reversal algorithm parallelizes well, because rotations can be split into sub-regions, which can be rotated independently of others.

References

  1. ^ Jon Bentley, "Programming Pearls", pp. 13–15, 209-211.