>웹 프론트엔드 >JS 튜토리얼 >JS에 구현된 몇 가지 일반적인 알고리즘

JS에 구현된 몇 가지 일반적인 알고리즘

高洛峰
高洛峰원래의
2016-12-07 10:03:21895검색

(1) 배열 중복 제거

원리: 객체 obj를 정의한 후 배열 요소를 obj의 속성명으로 사용하고, 속성명의 반복 여부를 이용하여 중복 여부를 판단합니다

var unique = function(arr){
  let obj = {};
  let newArr = [];
  arr.forEach(function(x){
    if(!obj[x]){ //如果对象中没有该元素对应的属性
      obj[x] = true;
      newArr.push(x);
    }
  });
  return newArr;
}


(2) 빠른 정렬 알고리즘을 사용하여 배열을 정렬합니다.

여기에는 두 가지 효과가 포함되며, 하나는 중복 제거를 달성하기 위한 퀵 정렬 퀵 정렬, 다른 하나는 가중치 제거가 없는 퀵 정렬입니다.

원리: 대상 배열을 구하고 플래그로 요소를 선택한 후 나머지 요소를 순회하여 플래그보다 큰 요소를 오른쪽에 배치하고 플래그보다 작은 요소를 왼쪽에 배치합니다.

특별 참고 사항: 플래그 비트와 동일한 요소가 있습니다. 동일한 요소를 저장하면 중복 제거가 수행됩니다.

var quickSort = function(arr){
  if(arr.length <= 1){
    return arr;
  }
  //定义一个左数组,定义一个右数组
  let leftArr = [];
  let rightArr = [];
  //选定一个参照值
  let tag = arr[0];
  /*
   * 使用如下方式判断,会把重复元素去掉,就实现了快排的同时去重
   */
  for(let i = 0; i < arr.length; i++){
    if(arr[i] < tag){ //将比tag小的元素放在左数组中
      leftArr.push(arr[i]);
    }
    if(arr[i] > tag){ //将比tag大的元素放在右数组中
      rightArr.push(arr[i]);
    }
  }
  /*
   * 使用如下方式就是使用快排进行排序,不去重
   */
  for(let i = 1; i < arr.length; i++){
    if(arr[i] < tag){ //将比tag小的元素放在左数组中
      leftArr.push(arr[i]);
    }else{ //将比tag大的元素放在右数组中
      rightArr.push(arr[i]);
    }
  }
  //递归调用
  return [].concat(quickSort(leftArr),[tag],quickSort(rightArr));
}


(3) 문자열에서 가장 자주 나타나는 문자를 센다

원리: 배열과 유사 deduplication 은 또한 객체 obj를 사용하여 배열 요소를 객체의 속성 이름으로 사용합니다. 속성 이름이 존재하지 않으면 값이 1로 할당됩니다. 존재하는 경우 값이 1씩 증가합니다.

var maxShowTimes = function(str){
  // 创建一个用于判重的对象
  let obj = {};
  // 判断字符串是否为空或只有一个元素
  if(str.length <= 1){
    return str.length === 0?&#39;字符串不能为空&#39;:str;
  }
  // 利用String的charAt()方法获取各个字符
  for(let i = 0; i <= str.length; i++){
    if(!obj[str.charAt(i)]){ //如果不存在
      obj[str.charAt(i)] = 1;
    }else{ //如果存在
      obj[str.charAt(i)] += 1;
    }
  }
  // 在obj对象中寻找值最大的那个属性
  let maxChar = &#39;&#39;;
  let maxTimes = 0;
  for(var k in obj){
    if(obj[k] > maxTimes){
      maxChar = k;
      maxTimes = obj[k];
    }
  }
  return maxChar;
}


(4) 세 번째 변수를 사용하지 않고 두 변수 간에 값을 교환합니다.

원리: 그냥 변수 대체 아이디어는 매우 영리하며 숫자 교환에만 사용할 수 있습니다.

var swap = function(a,b){
  if(a === b){
    return [a,b];
  }
  b = b - a; // 此处的 b - a中的b和a的值是最初的值
  a = a + b; // a = a + b -a; 实现了将b的值赋给a
  b = a - b; // b = a - (b - a) = 2a - b 相当于 2b = 2a;实现了将a的值赋给b
  return [a,b];
}


(5) 배열의 차이의 최대값을 구합니다.

원리: 배열을 한 번 순회하여 최대값을 찾습니다. sum 최소값, 차이 반환

var getMaxProfit = function(arr){
  // 定义两个变量,分别存贮最大值和最小值
  let maxNum = arr[0];
  let minNum = arr[0];
  for(let i = 0; i < arr.length; i++){
    if(arr[i] > maxNum){
      maxNum = arr[i];
    }
    if(arr[i] < minNum){
      minNum = arr[i];
    }
  }
  return maxNum - minNum;
}


(6) 임의의 길이의 문자열을 무작위로 가져옴

원칙: 당신 수동으로 할 수 있습니다 문자 라이브러리와 임의의 문자 길이 n을 지정하고 Math.floor() 및 Math.random() 메서드를 사용하여 임의의 문자를 얻습니다.

var getRandomString = function(n){
  // 定义随机字符串的字符库
  let str = &#39;qwertyuiopasdfghjklzxcvbnm1234567890&#39;;
  // 定义一个临时变量tmp存储生成的随机字符串
  let tmp = &#39;&#39;;
  //获取str的长度
  let len = str.length;
  // 生成一个长度为n的随机字符串
  for(let i = 0; i < n; i++){
    tmp += str.charAt(Math.floor(Math.random() * len));
  }
  return tmp;
}



성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.