Arrays and Iteration
Reverse Array In Place (Two Pointers)
Walk two indices toward each other from the ends of the array, swapping at each step. Stops when the indices meet or cross. Demonstrates the two-pointer pattern with the smallest possible state.
Algorithm
Canonical input [1, 2, 3, 4, 5, 6, 7] (odd length, middle element stays
put) yields three swap frames and reverses to [7, 6, 5, 4, 3, 2, 1].
Basic Implementation
basic.cpp
#include <iostream>
#include <vector>
int main() {
std::vector<int> arr = {1, 2, 3, 4, 5, 6, 7};
size_t left = 0;
size_t right = arr.size() - 1;
while (left < right) {
int tmp = arr[left];
arr[left] = arr[right];
arr[right] = tmp;
left = left + 1;
right = right - 1;
}
std::cout << "[";
for (size_t i = 0; i < arr.size(); ++i) {
if (i > 0) std::cout << ", ";
std::cout << arr[i];
}
std::cout << "]" << std::endl;
return 0;
}
Complexity
- Time: O(n)
- Space: O(1)
Implementation notes
- C++: use a temporary
int tmpto swap two slots. Never callstd::reverse(arr.begin(), arr.end()); the lesson is teaching the two-pointer walk. size_t leftandsize_t rightmirror the container'ssize()return type; theleft < rightguard handles the meet-in-the-middle exit honestly for the odd-length canonical input.- The replay shows both
leftandright, the values about to be swapped, and the array contents after the swap. The loop-exit frame is the moment the pointers meet.
two pointers
`left` starts at index `0`, `right` starts at `arr.size() - 1`. Each loop iteration swaps `arr[left]` and `arr[right]` and moves the pointers toward each other.