算法基础(二)

huozhonghun 2019-04-01 原文

算法基础(二)

例一

给定一个数组arr,和一个数num,请把小于等于num的数放在数 组的左边,大于num的数放在数组的右边。
要求额外空间复杂度O(1),时间复杂度O(N)

   public  static void partition(int[] arr, int l, int num) {
        int index=-1;
        while(l<arr.length){
            if(arr[l]<num)  swap(arr,++index,l++);
            else  l++;
        }
    }
    public static void swap(int[] arr, int i, int j){
        int temp=arr[i];
        arr[i]=arr[j];
        arr[j]=temp;
    }

例一(升级版)

给定一个数组arr,和一个数num,请把小于num的数放在数组的 左边,等于num的数放在数组的中间,大于num的数放在数组的 右边。
要求额外空间复杂度O(1),时间复杂度O(N)

  public static void partition(int[] arr, int l, int num) {
        int sindex=l-1;//前指标
        int eindex=arr.length;//后指标
        while(l<eindex){
            if(arr[l]<num)
                swap(arr,++sindex,l++);
            else if(arr[l]==num)
                l++;
            else
                swap(arr,--eindex,l);
         }
    }

    public static void swap(int[] arr, int i, int j){
        int temp=arr[i];
        arr[i]=arr[j];
        arr[j]=temp;
    }

 通过上面的例子引入经典快排

时间复杂度O(N*logN),额外空间复杂度O(logN)

  public static void quickSort(int[] arr) {
        if (arr == null || arr.length < 2) {
            return;
        }
        quickSort(arr, 0, arr.length - 1);
    }

    public static void quickSort(int[] arr, int l, int r) {
        if (l < r) {
       //加上下面一行就变成随机快排 //swap(arr, l
+ (int) (Math.random() * (r - l + 1)), r); int[] p = partition(arr, l, r); quickSort(arr, l, p[0] - 1); quickSort(arr, p[1] + 1, r); } } public static int[] partition(int[] arr, int l, int r) { int less = l - 1; int more = r; while (l < more) { if (arr[l] < arr[r]) { swap(arr, ++less, l++); } else if (arr[l] > arr[r]) { swap(arr, --more, l); } else { l++; } } swap(arr, more, r); return new int[] { less + 1, more }; } public static void swap(int[] arr, int i, int j) { int tmp = arr[i]; arr[i] = arr[j]; arr[j] = tmp; }

 堆排序

时间复杂度O(N*logN),额外空间复杂度O(1)

建堆的过程,时间复杂度为O(N)  

优先级队列结构,就是堆结构

public static void headSort(int[] arr){
        if(arr==null||arr.length<2)
            return;
        for (int i = 0; i < arr.length; i++) {
            headInsert(arr,i);//建成大根堆
        }
        int headSize=arr.length;
        swap(arr,0,--headSize);
        //堆顶和堆底交换,堆底元素移出比较
        while (headSize>0){
            heapify(arr,0,headSize);//重新调整成大根堆
            swap(arr,0,--headSize);
        }
    }

    //建大根堆
    public static void headInsert(int[] arr, int index) {
        while(arr[index]>arr[(index-1)/2]){
            swap(arr,index,(index-1)/2);
            index=(index-1)/2;
        }
    }
    //变成大根堆
    public static void heapify(int[] arr, int index, int size) {
        int left = index * 2 + 1;//根节点的左节点
        while (left < size) {//左节点没超过范围,一直作比较
            int largest = left + 1 < size && arr[left + 1] > arr[left] ? left + 1 : left;//找出左节点和右节点较大的元素
            largest = arr[largest] > arr[index] ? largest : index;//再与根节点比较,找出较大的元素
            if (largest == index) {//如果较大的元素还是根节点,节束,不用交换
                break;
            }
            swap(arr, largest, index);
            index = largest;//根节点移到交换的子节点,继续交换
            left = index * 2 + 1;
        }
    }
    public static void swap(int[] arr, int i, int j){
        int temp=arr[i];
        arr[i]=arr[j];
        arr[j]=temp;
    }

 

发表于 2019-04-01 16:46 不会敲代码的高手 阅读() 评论() 编辑 收藏

 

版权声明:本文为huozhonghun原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/huozhonghun/p/10628889.html

算法基础(二)的更多相关文章

  1. 数据结构与算法

    数据结构与算法 关于算法的代码写了一些在:https://gitee.com/yuan_yi_xiang/da […]...

  2. 快速排序

    快速排序 算法思路 选择一个数字 povit = array[low] 为关键字 目的就是为了确定关键字所在最 […]...

  3. 数据结构与算法(二)-线性表之单链表顺序存储和链式存储

    前言:前面已经介绍过数据结构和算法的基本概念,下面就开始总结一下数据结构中逻辑结构下的分支——线性结构线性表 […]...

  4. BitMap与RoaringBitmap、JavaEWAH

    本文主要介绍BitMap的算法思想,以及开源工具类JavaEWAH、RoaringBitmap的简单用法。 一 […]...

  5. 详细理解平衡二叉树AVL与Python实现

    前言 上一篇文章讨论的二叉搜索树,其时间复杂度最好的情况下是O(log(n)),但是最坏的情况是O(n),什么 […]...

  6. LeetCode——两数之和

      最近在家拧三阶魔方,把初级的玩法掌握了,也就是可以还原六个面了,速度不快,但是也很兴奋。三阶魔方的初级玩法 […]...

  7. 数据结构与算法(七)-树

    前言:回顾一下前面学习的内容,大概说了下数据结构中的线性结构,从物理存储方面来说又分为顺序存储和链式存储结构, […]...

  8. 数据结构和算法——二叉排序树

    给你一个数列 7, 3, 10, 12, 5, 1, 9,要求能够高效的完成对数据的查询和添加。 在 为什么需 […]...

随机推荐

  1. 推荐:C#命名规范12条

    编码规范对于程序员而言尤为重要,有以下几个原因: 1.一个项目的生命周期中,80%的花费在于维护; 2.几乎没 […]...

  2. 重新学习Mysql数据库3:Mysql存储引擎与数据存储原理

    转自:https://draveness.me/mysql-innodb 作为一名开发人员,在日常的工作中会难 […]...

  3. sublime text 前端开发插件安装和配置

    前端开发sublimeconfig mac配置 此文件目录中文件主要是关于sublime的插件配置,快捷键配置 […]...

  4. 数据挖掘十大经典算法一览

    分类算法:C4.5 ,svm,knn,朴素贝页斯,cart 聚类算法:k-means,em 关联挖掘算法:ap […]...

  5. 通信协议——Http、TCP、UDP

      CP   HTTP   UDP:  都是通信协议,也就是通信时所遵守的规则,只有双方按照这个规则“说话”, […]...

  6. python

    目录字符串end="":import 与 from...import数学函数字典dict空字典访问字典的值修改字典删除字典元素字典内置函数&方法元组访问元组修改元组删除元组元组截取元组内置函数列表list更新列表删除列表元素for冒个泡r...

  7. 吐血整理全网最全的单例模式

    前言 之前文章已经说过了设计模式的七大原则,即接口屏蔽原则,开闭原则,依赖倒转原则,迪米特原则,里氏替换原则, […]...

  8. (转载)应用程序开机自启动的C代码

    学习转载 文章出处  http://blog.csdn.net/my2005lb/article/detail […]...

展开目录

目录导航