 
 Data Structure Data Structure
 Networking Networking
 RDBMS RDBMS
 Operating System Operating System
 Java Java
 MS Excel MS Excel
 iOS iOS
 HTML HTML
 CSS CSS
 Android Android
 Python Python
 C Programming C Programming
 C++ C++
 C# C#
 MongoDB MongoDB
 MySQL MySQL
 Javascript Javascript
 PHP PHP
- Selected Reading
- UPSC IAS Exams Notes
- Developer's Best Practices
- Questions and Answers
- Effective Resume Writing
- HR Interview Questions
- Computer Glossary
- Who is Who
JavaScript Program for Block Swap Algorithm for Array Rotation
To implement block swap algorithm for array rotation, we will be understanding three different approaches. Rotation of the array elements means moving the elements of the given array to either the left or right side by some number of specific positions. Block swap algorithm for array rotation means to rotate the elements of the array by a given number but not using the rotation but the swapping technique.
In this article we are having an array and a variable d by which array will be rotated, our task is to write a JavaScript program for block swap algorithm for array rotation.
 
Example
Input: array: [1, 2, 3, 4, 5, 6, 7]; d: 3 Output: array after rotation by d: [4, 5, 6, 7, 1, 2, 3]
Block Swap Algorithm Approaches for Array Rotation
Here is a list of approaches for block swap algorithm for array rotation in javascript which we will be discussing in this article with stepwise explanation and complete example codes.
Iterative Blok Swap Approach
To implement block swap algorithm for array rotation, we are using iterative block swap approach. It breaks the array into two parts/segments and swap these segments iteratively.
- We have declared an array array and a variable d that represents number of positions to rotate the array. Then, we have defined function rotate() which accepts the array and d as arguments to perform the rotation.
- We have used the length property to get the length of the array and stored it in variable n.
- We have used if statement to check if the value of d is same as array length or 0, then no need to rotate.
- We have used two pointers i and j which divides the array in two segments. One segment having size equal to d and other n-d. We have used while loop to iterate over the elements till both pointers are not same.
- If the first segment is small i.e i < j, then we swap the first i elements from the beginning of the array with the first i elements from the second part. After swapping we adjust the pointer j by subtracting i from it.
- If the first segment is larger i.e i > j, then we swap the first j elements from the remaining array with the first j elements from the first part. After swapping we adjust the pointer i by subtracting j from it.
- After the loop one final swap is done to complete the rotation of all elements of the array. For swapping, we have used swap() function.
- Call the rotate() function with the arr1 and d as its argument. Print the result to the console using console.log() method.
Example
Here is a complete example code implementing above mentioned steps for block swap algorithm for array rotation by iterative block swap approach.
let array = [1, 2, 3, 4, 5, 6, 7];
let d = 3;
function rotate(array, d) {
    const n = array.length;
    if (d === 0 || d === n) return;
    let i = d; 
    let j = n - d;
    while (i !== j) {
        if (i < j) { 
            swap(array, d - i, d + j - i, i);
            j -= i;
        } else { 
            swap(array, d - i, d, j);
            i -= j;
        }
    }
    swap(array, d - i, d, i);
}
function swap(array, index1, index2, size) {
    for (let i = 0; i < size; i++) {
        [array[index1 + i], array[index2 + i]] = 
            [array[index2 + i], array[index1 + i]];
    }
}
rotate(array, d);
console.log("After rotation by d = " +d +":");
console.log(`[${array.join(", ")}]`);
Recursive Blok Swap Approach
In this article to implement block swap algorithm for array rotation, we are using recursive block swap approach. It breaks the array into smaller segments and recursively swap the segments of the array until the rotation is achieved.
- We have declared an array array and a variable d that represents number of positions to rotate the array. Then, we have defined function rotate() which accepts the array, d, and array size as arguments to perform the rotation.
- We have used if condition to check if the value of d is same as array length or 0 then no need to rotate.
- Then we check if the first segment d is smaller than second segment (n-d). If d < (n-d), then swap() function is called that swaps first d elements with the last d elements.
- After swapping, rotate() function is recursively called to rotate the remaining part of the array.
- If d > (n-d), then swap() function is called that swaps first d elements with the first d elements from the second part. After swapping, rotate() function is recursively called on remaining elements of the array.
- For swapping, we have used swap() function. Call the rotate() function with the arr1 and d as its argument. Print the result to the console using console.log() method.
Example
Here is a complete example code implementing above mentioned steps for block swap algorithm for array rotation by recursive block swap approach.
let array = [1, 2, 3, 4, 5, 6, 7];
let d = 3;
function rotate(array, d, n) {
    if (d === 0 || d === n) 
        return;
    if (d < n - d) {
        swap(array, 0, n - d, d);
        rotate(array, d, n - d);
    } else {
        
        swap(array, 0, d, n - d);
        rotate(array.slice(n - d), 0, d);
    }
}
function swap(array, index1, index2, size) {
    for (let i = 0; i < size; i++) {
        [array[index1 + i], array[index2 + i]] = 
            [array[index2 + i], array[index1 + i]];
    }
}
rotate(array, d, array.length);
console.log("After rotation by d = " +d +":");
console.log(`[${array.join(", ")}]`);
Complexity Comparison
Here is a comparison of time and space complexity of all the above approaches.
| Approach | Time Complexity | Space Complexity | 
|---|---|---|
| Iterative approach | O(n) | O(1) | 
| Recursive approach | O(n) | O(n) (due to slice()), O(1) otherwise | 
Practice and learn from a wide range of JavaScript examples, including event handling, form validation, and advanced techniques. Interactive code snippets for hands-on learning.
