基础算法(一)

目录

一.排序

快速排序:

归并排序:

二.二分法

整数二分模板:

浮点二分:


一.排序

快速排序:

  • 从数列中挑出一个元素,称为 "基准"
  • 重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区操作。
  • 递归把小于基准值元素的子数列和大于基准值元素的子数列排序。
java 复制代码
    static void quick_sort(int[] arr,int l,int r){

        if (l>=r) return;//特判小于等于1个的数组

        int x=arr[(l+r)>>1],i=l-1,j=r+1;//取分隔基准

        while (i<j){//把小于x的数放左边,大于x的数放右边

            //跳过已符合条件
            do i++; while (arr[i]<x);
            do j--; while (arr[j]>x);
            //交换使符合条件
            if (i<j){
                int t=arr[i];
                arr[i]=arr[j];
                arr[j]=t;
            }
        }

        //递归左右边排序
        quick_sort(arr,l,j);
        quick_sort(arr,j+1,r);
    }

归并排序:

利用归并(先递归排序子元素,再合并) 的思想实现的排序方法,该算法采用经典的分治 (divide-and-conquer)策略(分治法将问题 (divide)成一些小的问题然后递归求解,而(conquer)的阶段则将分的阶段得到的各答案"修补"在一起,即分而治之)。

java 复制代码
    static void merge_sort(int[] arr, int l, int r) {
        if (l >= r) return;

        int mid = l + r >> 1;
        merge_sort(arr, l, mid);//递归排序左
        merge_sort(arr, mid + 1, r);//右

        //合并
        int[] tmp = new int[arr.length];

        int k = 0, i = l, j = mid + 1;
        while (i <= mid && j <= r) {//从排序好的左右数组取最小依次放入tmp数组,知道某一个数组取完
            if (arr[i] < arr[j])
                tmp[k++] = arr[i++];
            else
                tmp[k++] = arr[j++];
        }
        //剩余部分直接放入tmp数组末尾
        while (i <= mid) tmp[k++] = arr[i++];
        while (j <= r) tmp[k++] = arr[j++];

        //tmp数组赋给原数组
        for (i = l, j = 0; i <= r; i++, j++) arr[i] = tmp[j];
    }

二.二分法

二分法的思想很简单,因为整个数组是单调的,每次判断后可将另外一半直接排除,大大提高查找效率,但是二分查找的边界问题很容易成为问题

整数二分模板:

java 复制代码
    static int binary_search1(int[] arr,int l, int r){
        while (l<r){
            int mid=l+r>>1;
            if (check(mid)){
                r=mid;
            }else {
                l=mid+1;
            }
        }
        return l;
    }

    static int binary_search2(int[] arr,int l,int r){
        while (l<r){
            int mid=l+r+1>>1;
            if(check(mid)){
                l=mid;
            }else {
                r=mid-1;
            }
        }
        return l;
    }

根据具体情况选择判断后边界的取值,特别注意不同边界下mid的初始化.

浮点二分:

java 复制代码
    static double binary_search3(double[] arr,double l,double r){
        final double eps=1e-6;
        while (r-l>eps){
            double mid=(l+r)/2;
            if (check(mid)) r=mid;
            else l=mid;
        }
        return l;
    }

浮点二分的核心在使用eps的精度进行判断

相关推荐
望舒51320 小时前
代码随想录day32,动态规划part1
java·算法·leetcode·动态规划
楠秋92020 小时前
代码随想录算法训练营第三十二天| 509. 斐波那契数 、 70. 爬楼梯 、746. 使用最小花费爬楼梯
数据结构·算法·leetcode·动态规划
㓗冽20 小时前
最大效益(二维数组)-基础题76th + 螺旋方阵(二维数组)-基础题77th + 方块转换(二维数组)-基础题78th
数据结构·算法
Ivanqhz20 小时前
数据流分析的核心格(Lattice)系统
开发语言·javascript·后端·python·算法·蓝桥杯·rust
琛説20 小时前
⚡PitchPPT:将PPT导出为高清全图PPT,并控制PPT文件大小在固定MB/GB以内【解析算法原理 · 作者谈】
windows·python·算法·github·powerpoint
We་ct20 小时前
LeetCode 25. K个一组翻转链表:两种解法详解+避坑指南
前端·算法·leetcode·链表·typescript
Hag_2020 小时前
LeetCode Hot100 438.找到字符串中的所有字母异位词
算法·leetcode·职场和发展
元亓亓亓20 小时前
LeetCode热题100--239. 滑动窗口最大值--困难
数据结构·算法·leetcode
闻缺陷则喜何志丹20 小时前
【进制】P2320 [HNOI2006] 鬼谷子的钱袋|普及+
c++·算法·进制
田里的水稻20 小时前
FA_融合和滤波(FF)-图优化
人工智能·算法·机器学习