An explanation (instead of code).
the canonical example of a linked list:
head -%26gt; node1 -%26gt; node2 -%26gt; node3 -%26gt; NULL
Starting at the first node of the list, look at the current node and the next node. If the two nodes are not in the correct order, swap them. Continue this until you reach the end. The end node will have NULL as the next pointer.
If you swapped any items at all, go back to the beginning of the list and do it all again.
Swapping can involve two different methods. If the stored item is small, such as a single integer, it's easier to just swap the integer value;s.
temp = node1.value;
node1.value = node2.value;
node2.value = temp;
If the item is larger, it's faster to change the pointers instead of the values.
In the original example, if we want to swap node1 and node2, we need to change the head pointer, node1.next and node2.next.
before swap
head == %26amp;node1;
node1.next = %26amp;node2;
node2.next = %26amp;node3;
I'll let you figure out the actual swap code
after swap
head == %26amp;node2;
node1.next = %26amp;node3;
node2.next = %26amp;node1;
Now the list looks like this:
head -%26gt; node2 -%26gt; node1 -%26gt; node3 -%26gt; NULL
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment