首页 > web前端 > js教程 > 正文

用于数组旋转的块交换算法的 JavaScript 程序

王林
发布: 2023-08-25 17:01:22
转载
1170人浏览过

用于数组旋转的块交换算法的 javascript 程序

数组元素的旋转意味着将给定数组的元素向左或向右移动一定数量的特定位置。我们假设数组为循环形式,并将边的元素旋转到另一端。数组旋转的块交换算法意味着将数组的元素旋转给定的数量,但不使用旋转而是使用交换技术。我们将实现递归和迭代方法。

输入

The given array is [ 1, 2, 3, 4, 5, 6, 7].
The number of rotations by which we have to rotate is 3. 
登录后复制

输出

[4, 5, 6, 7, 1, 2, 3]
登录后复制

说明

我们可以使用交换算法并获得结果,我们将在下一节中实现它。

递归方法

在这种方法中,我们将尝试假设我们有两个数组,第一个数组的大小为给定的旋转数,另一个数组的大小为总大小减去给定的元素数。

如果第一个数组的大小很小,那么我们将交换第一个数组的元素,最后一个元素等于第一个数组的大小,如果第一个数组的大小大于我们将交换第一个数组elements 等于给定数组的第二个数组的大小。

立即学习Java免费学习笔记(深入)”;

对于剩余元素,我们将通过更改交换数组来调用递归函数。

示例

function swap(arr, st, si, k){    
   // function to traverse over the array and swap the elements 
   for(var i = 0; i < k; i++) {
      var temp = arr[st + i];
      arr[st + i] = arr[si + i];
      arr[si + i] = temp;
   }
   return arr;
}
function rotate(arr, k, n){

   // if the number of rotations is zero or equal to the size of array
   // in this case we don't have to rotate the array 
   if(k == 0 || k == n){
      return;
   }
   
   // special case when the number of elements to rotate 
   // is half of the size of the given array
   if(n == 2*k){
      arr = swap(arr, 0, n - k, k);
      return;
   }		
   
   // if the first part is short	
   if(2*k < n) {
      arr = swap(arr, 0, n - k, k);
      rotate(arr, k, n - k);	
   }
   else{	
   
      // if second part is short
      arr = swap(arr, 0, k, n - k);
      rotate(arr + n - k, 2 * k - n, k);
   }
}

// function to print the given array 
function print(arr){
   var temp = "";
   for(var i = 0; i < arr.length; i++){
      temp += arr[i] + " ";
   }
   console.log(temp);
}

//Defining the array 
var arr = [1, 2, 3, 4, 5, 6, 7];
var num = 3;
console.log("The given array is: ");
print(arr);

// rotating the array 
rotate(arr, num, arr.length);
console.log("The given array after " + num + " number of rotations is: ")
print(arr);
登录后复制

时间和空间复杂度

上述代码的时间复杂度为N,其中N是给定数组的大小。

Picsart AI Image Generator
Picsart AI Image Generator

Picsart推出的AI图片生成器

Picsart AI Image Generator 37
查看详情 Picsart AI Image Generator

上述代码的空间复杂度为N,但这只是在我们考虑递归堆栈占用的内存的情况下。

迭代方法

迭代方法与递归方法相同,唯一的区别是我们在 while 循环中工作而不使用递归调用。让我们看看代码。

示例

function swap(arr, st, si, k){    
   // function to traverse over the array and swap the elements 
   for(var i = 0; i < k; i++) {
      var temp = arr[st + i];
      arr[st + i] = arr[si + i];
      arr[si + i] = temp;
   }
   return arr;
}
function rotate(arr, k, n){

   // if the number of rotations is zero or equal to the size of array
   // in this case we don't have to rotate the array 
   if(k == 0 || k == n){
      return;
   }
   var i = k;
   var j = n - k;
   while (i != j){
      if(i < j){
      
         // if the first array is shorter 
         arr = swap(arr, k - i, k + j - i, i);
         j -= i;
      }
      else{ 
      
         // if the second array is shorter 
         arr = swap(arr, k - i, k, j);
         i -= j;
      }
   }
   arr = swap(arr, k - i, k, i);
}

// function to print the given array 
function print(arr){
   var temp = "";
   for(var i = 0; i < arr.length; i++){
      temp += arr[i] + " ";
   }
   console.log(temp);
}

// defining the array 
var arr = [1, 2, 3, 4, 5, 6, 7];
var num = 3;
console.log("The given array is: ");
print(arr);

// rotating the array 
rotate(arr, num, arr.length);
console.log("The given array after " + num + " number of rotations is: ")
print(arr);
登录后复制

时间和空间复杂度

上述代码的时间复杂度为N,其中N是给定数组的大小。

上述代码的空间复杂度为 1 或常数,因为我们在这里没有使用任何额外的空间。

结论

在本教程中,我们实现了一个 JavaScript 程序,通过使用块交换算法将数组旋转给定的旋转次数。我们使用 O(N) 时间和 O(1) 空间复杂度的迭代方法实现了块交换算法,同时使用递归方法实现了 O(N) 空间复杂度。

以上就是用于数组旋转的块交换算法的 JavaScript 程序的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:tutorialspoint网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号