美文网首页
1.简单排序

1.简单排序

作者: _少年不知愁 | 来源:发表于2018-08-16 16:55 被阅读0次

1.冒泡
原理简单,一个个比较过去 缺点交换次数过多

 public static void main(String[] args) {
        Integer[] a = new Integer[]{3, 6, 2, 9, 4};

        sort(a);
        System.out.println(Arrays.toString(a));
    }

    public static void sort(Integer[] arr) {

        for (int i = 0; i < arr.length - 1; i++) {
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[i] > arr[j]) {
                    Integer arr1 = arr[i];
                    arr[i] = arr[j];
                    arr[j] = arr1;
                }
            }
        }
    }

2.选择排序
原理十分简单,先选择出最小(大)的放第一位,依次选择出来
这样只需[].length-1次交换

  public static void main(String[] args) {
        Integer[] a = new Integer[]{3, 2, 6, 100, 2, 9, 4};

        selectTest(a);
        System.out.println(Arrays.toString(a));
    }

    public static void selectTest(Integer[] arr) {
        int k = 0;
        for (int i = 0; i < arr.length - 1; i++) {
            k = i;
            for (int j = i; j < arr.length; j++) {
                if (arr[k] > arr[j]) {
                    k = j;
                }
            }

            Integer arr1 = arr[i];
            arr[i] = arr[k];
            arr[k] = arr1;
        }
    }

3.插入排序
原理:抓扑克牌,每抓一张牌插到指定位子

 public static void main(String[] args) {
       Integer[] a = new Integer[]{3, 2, 6, 100, 2, 9, 4};

       insertTest(a);
       System.out.println(Arrays.toString(a));
   }

   public static void insertTest(Integer[] arr) {

       for (int i = 1; i < arr.length; i++) {
           Integer tmp = arr[i];
           int j = i;

           while (j > 0 && arr[j-1] >= tmp) {
               arr[j] = arr[j - 1];
               j--;
           }
           arr[j] = tmp;
       }
   }

相关文章

  • 1.简单排序

    1.冒泡原理简单,一个个比较过去 缺点交换次数过多 2.选择排序原理十分简单,先选择出最小(大)的放第一位,依次选...

  • 选择排序-c语言描述

    选择排序分简单选择排序与堆排序两种,先介绍简单选择排序。1.简单选择排序在未排序的序列中找到最小(大)元素,存放到...

  • 用python实现各种排序

    从简单到复杂大致排序 1. 内置排序函数(不要太简单好吗) 2. 冒泡排序(排序的helloword) 3.插入排...

  • 【10天EXCEL精进特训营】day3不为认知的排序高级用法

    【学习笔记】 一、排序的基本用法(单个条件排序) 1. 简单排序:开始--排序和筛选--升序/降序 2. 快速排序...

  • 排序算法

    常见的排序算法有: 冒泡排序 快速排序 插入排序 归并排序 堆排序 1. 冒泡排序 冒泡排序是一种极其简单的排序算...

  • 常见的排序算法

    基于比较的排序(7种) 1.冒泡排序BubbleSort ** 1.1 基本思想 **冒泡排序是最简单粗暴的排序方...

  • 选择排序(Selection sort)

    1.瓦特 is 选择排序? 选择排序(Selection sort)是一种简单直观的[排序算法]。首先在未排序序列...

  • js常用的排序算法

    1.冒泡排序: 最简单的排序算法,代码实现:function bubbleSort(arr) {var len ...

  • 简单理解iOS7大排序算法

    1.插入排序 2.希尔排序 3.简单选择排序 4.堆排序 5.冒泡排序 6.快速排序 7.归并排序

  • 学习日志

    1.线性表的排序中的冒泡排序法,快速排序法,简单插入排序法和简单选择排序法在最坏情况下都是需要进行n(n-1)/2...

网友评论

      本文标题:1.简单排序

      本文链接:https://www.haomeiwen.com/subject/bnhobftx.html