1.排序算法

(1)冒泡排序,冒泡排序其实就是通过比较相邻位置的元素大小,如果左边比右边大,就交换位置,继续比较,实际上就是每轮比较都得出一个最大值,然后通过多伦比较得出。

  function bubbleSort(arr){

      for(var i=1;i<arr.length;i++){

        for(var j=0;j<arr.length-i;j++){ var temp; if(arr[j]>arr[j+1]){

          temp=arr[j];

          arr[j]=arr[j+1];

          arr[j+1]=temp;

        }

      }

    }

    return arr;

  }

(2)快速排序,我们选定一个数,然后比它小的都放在它左边,大于等于它的都放在它右边,那么这个时候对这个数来讲他的位置已经排到了正确的地方了,接下 来要做的就是在它的左右两边分别再进行类似操作。

     function quickSort(arr,l,r){

         var i,j,x;

         if(l<r){

            i=l;

            j=r;

            x=arr[i];

        while(i<j){

          while(i<j&&arr[j]>=x){

          j–;

        }

        if(i<j){

          arr[i]=arr[j];

        }

      while(i<j&&arr[i]<x){

          i++;

      }

      if(i<j){

        arr[j]=arr[i];

      }

    }

    arr[i]=x;

      //递归调用

    quickSort(arr,i+1,r);

    quickSort(arr,l,i-1);

    }

     return arr;

  }

2.阶段乘法

      function factorialize(num) {

          var result = num;

          if (num < 0) { return -1; } else if (num === 0 || num === 1) { return 1; } else { while (num > 1) {

            num–;

            result *= num;

          }

        }

        return result;

      }

3.回文字符串判断, 字符串忽略标点符号、大小写和空格,正着读和反着读一模一样,那么这个字符串就是palindrome(回文)

        function palindrome(str) {

              // 删除字符串中不必要的字符

            var re = /[W_]/g;

              // 将字符串变成小写字符

            var lowRegStr = str.toLowerCase().replace(re, ”);

              // 如果字符串lowRegStr的length长度为0时,字符串即是palindrome

              if (lowRegStr.length === 0) {

                  return true;

                }

            // 如果字符串的第一个和最后一个字符不相同,那么字符串就不是palindrome

            if (lowRegStr[0] !== lowRegStr[lowRegStr.length – 1]) {

                return false;

              } else {

                return palindrome(lowRegStr.slice(1, lowRegStr.length – 1));

            }

          }

4.翻转字符串方法

      (1)function reverseString(str) {

          var tmp = “”;

          for (var i = str.length – 1; i >= 0; i–) {

            tmp += str.charAt(i);

          }

          return tmp;

        }

      (2) function reverseString(s) {

            var arr = s.split(”);

            var i = 0, j = arr.length – 1;

            while (i < j) {

            var t = arr[i];

            arr[i] = arr[j];

            arr[j] = t;

            i++;

            j–;

          }

        return arr.join(”);

      }

5.数组中最大差值

      function getMaxProfit(arr) {

          var minPrice = arr[0];

          var maxProfit = 0;

          for (var i = 0; i < arr.length; i++) {

              var currentPrice = arr[i];

              minPrice = Math.min(minPrice, currentPrice);

              var potentialProfit = currentPrice – minPrice;

              maxProfit = Math.max(maxProfit, potentialProfit);

          }

        return maxProfit;

      }

6.随机指定长度字符串

      function randomString(n) {

          var str = ‘abcdefghijklmnopqrstuvwxyz9876543210’;

          var tmp = ”;

          var l = str.length;

          for(var i = 0; i < n; i++) {

            tmp += str.charAt(Math.floor(Math.random() * l));

          }

          return tmp;

      }

JavaScript 常用算法的更多相关文章

  1. JavaScript常用算法

    一.排序算法 1.Array.sort(function)(JavaScript原生排序算法)参数:比较函数(可选)若无参数,则按照首字母的ASCII码排序,比较函数的作用为确定排序 function ...

  2. javascript常用经典算法实例详解

    javascript常用经典算法实例详解 这篇文章主要介绍了javascript常用算法,结合实例形式较为详细的分析总结了JavaScript中常见的各种排序算法以及堆.栈.链表等数据结构的相关实现与 ...

  3. javascript中数组的常用算法深入分析

    Array数组是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array是前端必修的功课.本文将给大家详细介绍了javascri ...

  4. javascript常用排序算法实现

    毕业后,由于工作中很少需要自已去写一些排序,所以那些排序算法都忘得差不多了,不过排序是最基础的算法,还是不能落下啦,于是找了一些资料,然后用Javascript实现了一些常用的算法,具体代码如下: & ...

  5. javascript常用知识点集

    javascript常用知识点集 目录结构 一.jquery源码中常见知识点 二.javascript中原型链常见的知识点 三.常用的方法集知识点 一.jquery源码中常见的知识点 1.string ...

  6. Javascript常用的设计模式详解

    Javascript常用的设计模式详解 阅读目录 一:理解工厂模式 二:理解单体模式 三:理解模块模式 四:理解代理模式 五:理解职责链模式 六:命令模式的理解: 七:模板方法模式 八:理解javas ...

  7. GIS常用算法

    目录 1.常用算法 1.1.计算两经纬度点之间的距离 1.2.根据已知线段以及到起点距离,求目标点坐标 1.3.已知点.线段,求垂足 1.4.线段上距离目标点最近的点 1.5.点缓冲 1.6.点和面关 ...

  8. 总结Objective-c常用算法

          今天是星期天,想睡到10点起床,结果认为自己太奢侈了,不能这么做,于是把闹钟设置成了6:30:结果终于9:36醒了,起床,无缘无故迟了,好吧,就算太累了吧,周天就原谅自己一回.终于到了中午 ...

  9. JavaScript 常用功能总结

    小编吐血整理加上翻译,太辛苦了~求赞! 本文主要总结了JavaScript 常用功能总结,如一些常用的JS 对象,基本数据结构,功能函数等,还有一些常用的设计模式. 目录: 众所周知,JavaScri ...

随机推荐

  1. SVN 文件解锁

    之前一直一个人用svn,后来团队扩编,同事使用svn下载项目后.我却无法提交了,出现以下错误: locked in another working copy No lock on path (Stat ...

  2. setImageBitmap和setImageResource

    同样的布局文件,小分辨率手机: 1.使用setImageBitmap设置时,出现如下现象:  2.使用setImageResource时,图片显示正常 原因: setImageResource(id) ...

  3. 编写更好的jQuery代码的建议(share)

    留个备份! 原文链接: Mathew Carella   翻译: 伯乐在线- yanhaijing译文链接: http://blog.jobbole.com/52770/ 讨论jQuery和javas ...

  4. hdu4666 Hyperspace ——曼哈顿距离

    link:http://acm.hdu.edu.cn/showproblem.php?pid=4666 这题学会了怎么处理曼哈顿距离. 比如维数是k,那么每个点有2^k个状态,求出在每个状态下,所有点 ...

  5. HTML5实战与剖析之触摸事件(touchstart、touchmove和touchend)

    HTML5中新添加了很多事件,但是由于他们的兼容问题不是很理想,应用实战性不是太强,所以在这里基本省略,咱们只分享应用广泛兼容不错的事件,日后随着兼容情况提升以后再陆续添加分享.今天为大家介绍的事件主 ...

  6. Android——什么是3G

    第三代数字通讯技术(3id Generation) 3G与2G的主要区别是:在传输声音和数据的速度上的提升. 1995年问世的第一代模拟制式手机1G只能进行语音通话. 1996年出现的第二代GSM C ...

  7. 数迹学——Asp.Net MVC4入门指南(4):添加一个模型

    一.添加模型类 二.添加MovieDBContext类,连接数据库 DbContext类继承自 System.Data.Entity; 负责在数据库中获取,存储,更新,处理实例 MovieDBCont ...

  8. Oracle11g的delayed failed logins特性引起的性能问题

    用户反映修改密码后程序明显变慢,查看AWR发现: ASH信息如下: 进一步验证: SQL>select event,p1 from v$session t where t.username is ...

  9. Alpha版本——Postmortem会议

    No Bug 031402401鲍亮 031402402曹鑫杰 031402403常松 031402412林淋 031402418汪培侨 031402426许秋鑫 设想和目标 1.我们的软件要解决什么 ...

  10. mongoose学习文档

    名词解释 Schema : 一种以文件形式存储的数据库模型骨架,不具备数据库的操作能力 Model : 由Schema发布生成的模型,具有抽象属性和行为的数据库操作对 来自cnode社区 1.创建一个 ...