算法图解-读书笔记

算法简介

二分查找:基于有序数组开展

大O表示法:时间复杂度空间复杂度,主要用于衡量随着n的变化,时间复杂度和空间复杂度的增速

选择排序

数组、链表:两者在数据存取方面的时间复杂度的区别,
选择排序:
原理:每次遍历序列获取最大、或最小的元素,;循环遍历,所有元素

递归

递归:自己调用自己的函数,递归和循环实现原理相同,只是表现形式不同,递归的形式可读性更好,但占用的调用栈内存更大,循环的内存消耗更小

递归包含:基线条件、循环条件

快速排序

例如前面提到的二分查找,一些操作是基于有序序列的,所以需要对数据进行排序

分而治之:有时遇到已有算法无法解决的问题,应该尝试已有的解决办法找出解决方式,分而治之是一种重要的解决思路

快排:基于分而治之的思路,

基线条件:数据的长度<2,不需要排序;

循环:数据长度>=2,将数据分为三部分:<pivot的数组,pivot,>pivot的数组,

对于pivot左右的数组,继续采用分治思路拆分,知道满足基线条件;

再将排好序的子数组和pivot,拼接好返回;

分而治之的原理:

找到基线条件

确定如何缩小问题的规模,使其符合基线条件

通过实现比较快排和归并排序的时间复杂度

算法实现

选择排序
var chooseSort = function (arr){
    if(!arr||arr.length<2){
        return arr;
    }
    var max = arr[0],index=0;
    for(var i=0;i<arr.length;i++){
        max = arr[i];
        index=i;
        for(var j=i+1;j<arr.length;j++){
            if(arr[j]>max){
                max=arr[j];
                index=j;
            }
        }
        swap(arr,i,index);
    }
    return arr;
}
var swap=function(arr,i,index){
    var temp = arr[i];
    arr[i]=arr[index];
    arr[index]=temp;
}
快排
var DC_sort = function (left,right,arr){
    var pivot = arr[left];
    while (left<right){
        while (left<right&&arr[right]>=pivot)  right--;
        arr[left] = arr[right];
        while (left<right&&arr[left]<=pivot) left++;
        arr[right] = arr[left];
    }
    arr[left]=pivot;
    return left;
}
var quickSort = function (low,high,arr){
    if(low>=high){
        return;
    }
    var positon = DC_sort(low,high,arr);
    quickSort(low,positon-1,arr);
    quickSort(positon+1,high,arr);
    return arr;
}
var arr=[7,8,3,5];
console.log(quickSort(0, arr.length - 1, arr));
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言是一种广泛应用于计算机科学和软件开发的编程语言。它具有强大的功能和灵活性,适用于开发各种类型的应用程序。 C语言专题精讲篇是一个对C语言进行深入学习和讲解的系列文章或课程。它汇总了C语言相关的重要知识点和技巧,旨在帮助学习者更好地理解和运用C语言。 这个专题中的笔记涵盖了C语言的各个方面,包括基本语法、数据类型、运算符、流程控制、函数、数组、指针、结构体、文件操作等。通过系统性的学习和总结,这些笔记可以帮助学习者逐步掌握C语言的核心概念和常用技巧。 在这个专题中,学习者可以学到如何编写简单的C程序,如何使用变量和运算符进行计算,如何使用条件和循环语句控制程序流程,如何使用函数进行代码的模块化,如何使用数组和指针进行数据的处理,如何使用结构体组织复杂数据,如何进行文件的读写等等。 C语言专题精讲篇的目的是帮助学习者全面、深入地了解C语言的各个方面,并能够独立编写和调试简单到中等难度的C程序。通过反复实践和练习,学习者可以逐渐提高自己的编程能力,并为进一步学习更高级的编程语言打下坚实的基础。 总之,C语言专题精讲篇的笔记汇总是一份重要的学习资料,可以帮助学习者系统地学习和掌握C语言的基础知识和常用技巧,为他们未来的编程之路打下坚实的基石。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值