资讯专栏INFORMATION COLUMN

常见算法

learn_shifeng / 2212人阅读

摘要:算法题斐波拉契数列冒泡排序好中坏改进版初始时最后位置保持不变每趟开始时无记录交换记录交换的位置为下一趟排序作准备选择排序好中坏插入排序好平坏希尔排序好中坏归并排序好平坏采用自上而下的递归方法快速排序好平坏

算法题 斐波拉契数列

</>复制代码

  1. function f(n) {
  2. if (n == 0 || n == 1) {
  3. return n;
  4. }
  5. else {
  6. return f(n-1) + f(n - 2);
  7. }
  8. }
1.冒泡排序

好、中、坏:O(n)、O(n^2)、O(n^2)

</>复制代码

  1. function bubbleSort(arr) {
  2. var len = arr.length;
  3. var temp;
  4. for (var i = len; i >= 2; --i) {
  5. for (var j = 0; j <= i - 1; ++j) {
  6. if (arr[j] > arr[j + 1]) {
  7. temp = arr[j];
  8. arr[j] = arr[j + 1];
  9. arr[j + 1] = temp;
  10. }
  11. }
  12. }
  13. return arr;
  14. };

改进版:

</>复制代码

  1. function bubbleSort2(arr) {
  2. var i = arr.length-1; // 初始时,最后位置保持不变
  3. while ( i> 0) {
  4. var pos= 0; // 每趟开始时,无记录交换
  5. for (var j= 0; j< i; j++)
  6. if (arr[j]> arr[j+1]) {
  7. pos= j; // 记录交换的位置
  8. var tmp = arr[j]; arr[j]=arr[j+1];arr[j+1]=tmp;
  9. }
  10. i= pos; //为下一趟排序作准备
  11. }
  12. return arr;
  13. }
2.选择排序

好 中 坏 : O(n^2)、O(n^2)、O(n^2)

</>复制代码

  1. function selectionSort(arr) {
  2. var min, temp;
  3. var len = arr.length;
  4. for (var i = 0; i < len - 1; ++i) {
  5. min = i;
  6. for (var j = i + 1; j < len; ++j) {
  7. if (arr[j] < arr[min]) {
  8. min = j;
  9. }
  10. temp = arr[i];
  11. arr[i] = arr[min];
  12. arr[min] = temp;
  13. }
  14. }
  15. return arr;
  16. }
3.插入排序

好、平、坏:O(n^2)、O(n)、O(n^2)

</>复制代码

  1. function insertSort(arr) {
  2. var temp, i;
  3. var len = arr.length;
  4. for (var j = 1; j <= len - 1; ++j) {
  5. temp = arr[j];
  6. i = j;
  7. while (i > 0 && (arr[i - 1] >= temp)) {
  8. arr[i] = arr[i - 1];
  9. --i;
  10. }
  11. arr[i] = temp;
  12. }
  13. return arr;
  14. }
4.希尔排序

好 中 坏 : O(n^1.3)、O(nlogn)-O(n^2)、O(n^2)

</>复制代码

  1. function shellsort(arr) {
  2. var len = arr.length;
  3. var h = 1;
  4. while (h < len / 3) {
  5. h = 3 * h + 1;
  6. }
  7. while (h >= 1) {
  8. for (var i = h; i < len; i++) {
  9. for (var j = i; j >= h && arr[j] < arr[j-h];j -= h) {
  10. temp = arr[j];
  11. arr[j] = arr [j - h];
  12. arr[j - h] = temp;
  13. }
  14. }
  15. h = (h-1)/3;
  16. }
  17. return arr;
  18. }
5.归并排序

好、平、坏:O(nlogn)、O(nlogn)、O(nlogn)

</>复制代码

  1. function mergeSort(arr) { //采用自上而下的递归方法
  2. var len = arr.length;
  3. if(len < 2) {
  4. return arr;
  5. }
  6. var middle = Math.floor(len / 2),
  7. left = arr.slice(0, middle),
  8. right = arr.slice(middle);
  9. return merge(mergeSort(left), mergeSort(right));
  10. }
  11. function merge(left, right)
  12. {
  13. var result = [];
  14. while (left.length && right.length) {
  15. if (left[0] <= right[0]) {
  16. result.push(left.shift());
  17. } else {
  18. result.push(right.shift());
  19. }
  20. }
  21. while (left.length)
  22. result.push(left.shift());
  23. while (right.length)
  24. result.push(right.shift());
  25. return result;
  26. }
6.快速排序

好、平、坏:O(nlogn)、O(nlogn)、O(n^2)

</>复制代码

  1. function qSort(arr) {
  2. var len = arr.length;
  3. if (len == 0) {
  4. return [];
  5. }
  6. var left = [];
  7. var right = [];
  8. var flag = arr[0];
  9. for (var i = 1; i < len; i++) {
  10. if (arr[i] < flag) {
  11. left.push(arr[i]);
  12. }
  13. else {
  14. right.push(arr[i]);
  15. }
  16. }
  17. return qSort(left).concat(flag, qSort(right));
  18. }
  19. ///////////////////////////////////////////////////////
  20. var arr = [2,1,3,4,3];
  21. var m = qSort(arr);
  22. console.log(m); //[1, 2, 3, 3, 4]
BST遍历

</>复制代码

  1. // 中序:
  2. function inOrder(node) {
  3. if (!(node == null)) {
  4. inOrder(node.left);
  5. putstr(node.show() + " ");
  6. inOrder(node.right);
  7. }
  8. }
  9. // 先序:
  10. function preOrder(node) {
  11. if (!(node == null)) {
  12. putstr(node.show() + " ");
  13. preOrder(node.left);
  14. preOrder(node.right);
  15. }
  16. }
  17. // 后序:
  18. function postOrder(node) {
  19. if (!(node == null)) {
  20. postOrder(node.left);
  21. postOrder(node.right);
  22. putstr(node.show() + " ");
  23. }
  24. }

DFS&BFS

</>复制代码

  1. // 深度优先遍历
  2. function dfs(v) {
  3. this.marked[v] = true;
  4. for each(var w in this.adj[v]) {
  5. if (!this.marked[w]) {
  6. this.dfs(w);
  7. }
  8. }
  9. }
  10. // 广度优先遍历
  11. function bfs(s) {
  12. var queue = [];
  13. this.marked[s] = true;
  14. queue.push(s); // 添加到队尾
  15. while (queue.length > 0) {
  16. var v = queue.shift(); // 从队首移除
  17. if (v == undefined) {
  18. print("Visisted vertex: " + v);
  19. }
  20. for each(var w in this.adj[v]) {
  21. if (!this.marked[w]) {
  22. this.edgeTo[w] = v;
  23. this.marked[w] = true;
  24. queue.push(w);
  25. }
  26. }
  27. }
  28. }
二分搜索算法

</>复制代码

  1. function binSearch(arr, data) {
  2. var upperBound = arr.length-1;
  3. var lowerBound = 0;
  4. while (lowerBound <= upperBound) {
  5. var mid = Math.floor((upperBound + lowerBound) / 2);
  6. if (arr[mid] < data) {
  7. lowerBound = mid + 1;
  8. }
  9. else if (arr[mid] > data) {
  10. upperBound = mid - 1;
  11. }
  12. else {
  13. return mid;
  14. }
  15. }
  16. return -1;
  17. }

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/82175.html

相关文章

  • 逆向中常见的Hash算法和对称加密算法的分析

    摘要:逆向中常常出现一些加密算法,如果我们能对这些加密算法进行快速识别则会大大减少我们逆向的难度,虽然已有密码分析神器,但掌握手动分析方法能帮助我们应对更多的情况。这篇文章将介绍逆向中常见的单项散列算法和对称加密算法的识别方法。 逆向中常常出现一些加密算法,如果我们能对这些加密算法进行快速识别则会...

    hedzr 评论0 收藏0
  • 数据结构与算法:常见排序算法

    摘要:这是一个简单的递归函数,你可以使用它来生成数列中指定序号的数值这个函数的问题在于它的执行效率非常低有太多值在递归调用中被重新计算。 本章内容衔接上一章 数据结构与算法:二分查找 内容提要 两种基本数据结构: 数组 常见操作: 数组降维、数组去重 链表 递归:递归是很多算法都使用的一种编程方法   - 如何将问题分成基线条件和递归条件   - 分而治之策略解决棘手问题 ...

    wuyumin 评论0 收藏0
  • 数据结构与算法:常见排序算法

    摘要:这是一个简单的递归函数,你可以使用它来生成数列中指定序号的数值这个函数的问题在于它的执行效率非常低有太多值在递归调用中被重新计算。 本章内容衔接上一章 数据结构与算法:二分查找 内容提要 两种基本数据结构: 数组 常见操作: 数组降维、数组去重 链表 递归:递归是很多算法都使用的一种编程方法   - 如何将问题分成基线条件和递归条件   - 分而治之策略解决棘手问题 ...

    Carson 评论0 收藏0
  • 常见gc算法

    摘要:根搜索算法它的处理方式就是,设立若干种根对象,当任何一个根对象到某一个对象均不可达时,则认为这个对象是可以被回收的。 引用计数算法 给对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就加1;当引用失效时,计数器值就减1;任何时刻计数器为0的对象就是不可能再被使用的。 缺点:引用和去引用伴随加法和减法,影响性能。 致命的缺陷:对于循环引用的对象无法进行回收。 根搜索算法 它的...

    Leo_chen 评论0 收藏0
  • 几种常见排序算法

    摘要:本文介绍几种常见排序算法选择排序,插入排序,希尔排序,归并排序,快速排序,堆排序,对算法的思路性质特点具体步骤实现以及图解进行了全面的说明。最后对几种排序算法进行了比较和总结。 本文介绍几种常见排序算法(选择排序,插入排序,希尔排序,归并排序,快速排序,堆排序),对算法的思路、性质、特点、具体步骤、java实现以及trace图解进行了全面的说明。最后对几种排序算法进行了比较和总结。 写...

    ChristmasBoy 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<