Java实现插入排序

 更新时间:2021年08月27日 09:09:28   作者:这个对数不太对  
这篇文章主要介绍了Java实现插入排序,把一列数组按从小到大或从大到小排序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

问题描述

利用插入排序把一列数组按从小到大或从大到小排序

(一)、插入排序思想

以从小到大为例:

1、第一轮插入,从第二个数开始,与前面的数依次比较,遇到比自己小的数,就插入到该数后面的位置
2、第二轮插入,从第三个数开始,与前面的数依次比较,遇到比自己小的数,就插入到该数后面的位置
3、如此循环,直到所有数从小到大排列

(二)、问题分析

1. 输入数组

根据用户输入的进行排序的数字数量n,建立一个长度为n的数组

public static void main (String[] args){
  int n,m;
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入你想排序的数量n");
        n=sc.nextInt();
        
        int [] arrary = new int[n];
        System.out.println("请输入"+n+"个数,并用空格隔开");
        
        for(int i=0;i<arrary.length;i++){
            arrary[i]=sc.nextInt();
        }

2.输入如何排序

设置两条路径:m=1为从小到大,m=2为从大到小,m=其他 提醒用户重新输入

System.out.println("请问你想:1.从小到大 2.从大到小 排序?");
        m=sc.nextInt();

        while (m!=1 && m!=2 ){
            System.out.println("输入有误请再次输入");
            m = sc.nextInt();
            continue;
        }

3.排序算法

(1)数组长度 arrary.length 也就是用户输入的 n
(2)j 表示第 j 轮排序,这里面n-1轮排序就已足够
(3)k 表示第 k+1 个位置,arrary[k] 表示第 k+1 个位置的数
(4)每一轮的 k 从 j-1 开始,向前依次比较,每比较一次做一次k- -,直到遇到比该数小的数,则插入到这个较小数的后面
(5)上述想法可转换为:每一轮的 arrary[k+1] 与其前面比自己大的数交换位置,遇到比自己小的数则停止
(6)较大数与较小数交换位置的经典算法:若a>b; 则c=a; a=b; b=c;
(7)从大到小排序只需把 arrary[k]>arrary[k+1] 换成 arrary[k]<arrary[k+1] 即可
(8)选择进行何种排序,在 if 语句的判断框里加上此时m应该等于的值
(9)因为要先选择进行何种排序,才能进行排序,所以把 m==1 放在 arrary[k]>arrary[k+1] 前面,且用短板与 && ,这样更易于理解(如果m≠1,则直接进行else if 的语句)
(10)也可以 m==1 & arrary[k]>arrary[k+1] 或 arrary[k]>arrary[k+1] & m==1,但不能 arrary[k]<arrary[k+1] && m==2。

for (int j=1;j<arrary.length;j++){
            for (int k=j-1;k>=0;k--){
                if(m==1 && arrary[k+1]<arrary[k] ){
                    int a=arrary[k+1];
                    arrary[k+1]=arrary[k];
                    arrary[k]=a;
                }
                else if(m==2 && arrary[k]>arrary[k+1]){
                    int a=arrary[k+1];
                    arrary[k+1]=arrary[k];
                    arrary[k]=a;
                }

            }
        }

4.输出数组

由于输出的是一段数组,所以还需要引用一段 for 语句

System.out.print("选择"+m+"的结果为:");
        for(int j=0;j<arrary.length;j++)
            System.out.print(arrary[j]+" ");

(三)、完整代码

把上述代码整理一下

import java.util.Scanner;
public class Insertion {
    public static void main (String[] args){
        int n,m;
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入你想排序的数量n");
        n=sc.nextInt();

        System.out.println("请问你想:1.从小到大 2.从大到小 排序?");
        m=sc.nextInt();

        while (m!=1 && m!=2 ){
            System.out.println("输入有误请再次输入");
            m = sc.nextInt();
            continue;
        }

        int [] arrary = new int[n];
        System.out.println("请输入"+n+"个数,并用空格隔开");
        for(int i=0;i<arrary.length;i++){
            arrary[i]=sc.nextInt();
        }

        for (int j=1;j<arrary.length;j++){
            for (int k=j-1;k>=0;k--){
                if(m==1 && arrary[k+1]<arrary[k] ){
                    int a=arrary[k+1];
                    arrary[k+1]=arrary[k];
                    arrary[k]=a;
                }
                else if(m==2 && arrary[k]>arrary[k+1]){
                    int a=arrary[k+1];
                    arrary[k+1]=arrary[k];
                    arrary[k]=a;
                }

            }
        }

        System.out.print("选择"+m+"的结果为:");
        for(int j=0;j<arrary.length;j++)
            System.out.print(arrary[j]+" ");

    }
}

(四)、运行结果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • SpringBoot集成PageHelper及使用方法详解

    SpringBoot集成PageHelper及使用方法详解

    这篇文章主要介绍了SpringBoot集成PageHelper及使用方法详解,PageHelper 是一个开源的 Java 分页插件,它可以帮助开发者简化分页操作,本文提供部分相关代码,需要的朋友可以参考下
    2023-10-10
  • Java聊天室之实现一个服务器与多个客户端通信

    Java聊天室之实现一个服务器与多个客户端通信

    这篇文章主要为大家详细介绍了Java简易聊天室之实现一个服务器与多个客户端通信,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以了解一下
    2022-10-10
  • Java实现的文件过滤代码分享(按后辍过滤)

    Java实现的文件过滤代码分享(按后辍过滤)

    这篇文章主要介绍了Java实现的文件过滤代码分享,本文通过后辍名过滤,代码写简洁,容易看懂,需要的朋友可以参考下
    2014-07-07
  • Java实现pdf转图片案例

    Java实现pdf转图片案例

    这篇文章主要介绍了Java实现pdf转图片案例,按照步骤放置代码,一步步完成该案例,将代码部署便可,需要的朋友可以参考下
    2021-06-06
  • SpringAop如何通过某个子类切父类

    SpringAop如何通过某个子类切父类

    这篇文章主要介绍了SpringAop如何通过某个子类切父类,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • Java中一个线程执行死循环有什么后果

    Java中一个线程执行死循环有什么后果

    这篇文章主要为大家详细介绍了Java中一个线程执行死循环有什么后果,当一个线程在执行死循环时会影响另外一个线程吗,下面为大家揭晓
    2016-05-05
  • springboot 同时启用http/https的配置方法

    springboot 同时启用http/https的配置方法

    本文给大家分享springboot 同时启用http/https的配置方法,通过修改配置文件、增加java配置的方法来实现此操作,具体内容详情跟随小编通过本文学习下吧
    2021-05-05
  • java环境变量如何配置

    java环境变量如何配置

    这篇文章主要为大家详细介绍了java环境变量配置教程,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • springboot+nacos+gateway实现灰度发布的实例详解

    springboot+nacos+gateway实现灰度发布的实例详解

    灰度发布是一种在软件部署过程中用于平滑过渡的技术,通过引入灰度发布SDK和配置网关策略实现,本文就来介绍一下,感兴趣的可以了解一下
    2022-03-03
  • 使用Java语言实现一个冒泡排序

    使用Java语言实现一个冒泡排序

    冒泡排序也是一种简单直观的排序算法,基本思想是多次遍历要排序的数组,每次比较相邻的元素,如果顺序不对就交换它们的位置,本篇文章将通过IDE使用 Java 语言实现一个冒泡排序,需要的朋友可以参考下
    2024-03-03

最新评论