• js 实现数组元素交换位置


    /**
    * 数组元素交换位置
    * @param {array} arr 数组
    * @param {number} index1 添加项目的位置
    * @param {number} index2 删除项目的位置
    * index1和index2分别是两个数组的索引值,即是两个要交换元素位置的索引值,如1,5就是数组中下标为1和5的两个元素交换位置
    */
    function swapArray(arr, index1, index2) {
       arr[index1] = arr.splice(index2, 1, arr[index1])[0];
        return arr;
    }
    
    //上移 将当前数组index索引与后面一个元素互换位置,向数组后面移动一位
    
    function zIndexUp(arr,index,length){
       if(index+1 != length){
           swapArray(arr, index, index+1);
       }else{
          alert(‘已经处于置顶,无法上移‘);
      }
    }
    
    //下移 将当前数组index索引与前面一个元素互换位置,向数组前面移动一位
    
    function zIndexDown(arr,index,length){
       if(index!= 0){
           swapArray(arr, index, index-1);
       }else{
          alert(‘已经处于置底,无法下移‘);
      }
    }
    
    //置顶,即将当前元素移到数组的最后一位
    
    function zIndexTop(arr,index,length){
       if(index+1 != length){
    
         //首先判断当前元素需要上移几个位置,置底移动到数组的第一位
          var moveNum = length - 1 - index;
    
          //循环出需要一个一个上移的次数
           for (var i = 0; i<moveNum; i++) {
    
             swapArray(arr, index, index + 1);
    
              index++;
    
         }
       }else{
          alert(‘已经处于置顶‘);
      }
    }
    
    //置底,即将当前元素移到数组的第一位
    
    function zIndexBottom(arr,index,length){
       if(index!=0){
    
          //首先判断当前元素需要上移几个位置,置底移动到数组的第一位
          var moveNum = index - 0;
    
          //循环出需要一个一个上移的次数
           for (var i = 0; i<moveNum; i++) {
    
             swapArray(arr, index, index - 1);
    
              index--;
    
         }
       }else{
          alert(‘已经处于置底‘);
      }
    }
  • 相关阅读:
    65 进程互斥锁的优化实现
    Linux多线程编程
    互斥锁和自旋锁
    64 进程互斥锁的初步实现(下)
    63 进程互斥锁的初步实现(中)
    Linux中断子系统
    62 进程互斥锁的初步实现(上)
    61 进程互斥锁的详细设计
    Linux进程调度的时机
    嵌入式领域linux作为实时操作系统的缺点(转)
  • 原文地址:https://www.cnblogs.com/plBlog/p/13906288.html
Copyright © 2020-2023  润新知