算法提高 插入排序

时间限制:1.0s 内存限制:256.0MB

  

  插入排序

问题描述

  排序,顾名思义,是将若干个元素按其大小关系排出一个顺序。形式化描述如下:有n个元素a[1],a[2],…,a[n],从小到大排序就是将它们排成一个新顺序a[i[1]]<a[i[2]]<…<a[i[n]]

  i[k]为这个新顺序。

  插入排序,顾名思义,是通过插入操作完成排序。其直觉和方法来源于打牌时安排牌的方法。每次摸起一张牌,你都会将其插入到现在手牌中它按顺序应在的那个位置。插入排序每一步都类似这个摸牌过程。比如现在有整数数组:{3, 1, 5, 4, 2}

  第一步:插入3 得到新序列{3}

  第二步:插入1 得到新序列{1 3}

  第三步:插入5 得到新序列{1 3 5}

  第四步:插入4 得到新序列{1 3 4 5}

  第五步:插入2 得到新序列{1 2 3 4 5}

  为了看程序中如何完成插入过程,我们以第五步为例:

  初始时:1 3 4 5 2

  将2存入临时变量tmp

  将下标j指向2之前的元素5,然后根据tmp和a[j]的大小关系决定该元素是否应该后移。如果a[j]>tmp,则将a[j]后移到a[j+1],序列变成1 3 4 5 5。

  将下标j前移

  判断a[j]>tmp,后移a[j]到a[j+1],得到1 3 4 4 5

  将下标j前移

  判断a[j]>tmp,后移a[j]到a[j+1],得到1 3 3 4 5

  因为a[j]<=tmp,所以将tmp放回a[j+1],得到 1 2 3 4 5

  现在,输入n个整数,根据以上算法,输出插入排序的全过程。

输入格式

  第一行一个正整数n,表示元素个数

  第二行为n个整数,以空格隔开

输出格式

  有n个元素,因此输出部分分为n个部分,每个部分开头行为:Insert element[i],i为第几个元素。然后对于每一个部分,输出该部分该元素在插入排序过程中的每一步产生的新序列,初始时的序列以Init:打头,然后每一步后移数组元素后的元素序列以Move back:打头,最后得到的最终结果序列以Final:打头。序列元素间以一个空格隔开。示例请看样例输出。每一个部分的Insert element[i]之后的每一步的输出行之前要缩进两格,即输出两个空格。

样例输入

5

3 1 5 4 2

样例输出

Insert element[1]:

Init:3

Final:3

Insert element[2]:

Init:3 1

Move back:3 3

Final:1 3

Insert element[3]:

Init:1 3 5

Final:1 3 5

Insert element[4]:

Init:1 3 5 4

Move back:1 3 5 5

Final:1 3 4 5

Insert element[5]:

Init:1 3 4 5 2

Move back:1 3 4 5 5

Move back:1 3 4 4 5

Move back:1 3 3 4 5

Final:1 2 3 4 5

数据规模和约定

  n<=100

  整数元素在int范围内

import java.util.Scanner;

public class 插入排序 {
public static void main(String[] args) {
Scanner s=new Scanner(System.in);
int a=s.nextInt();
int[] arr=new int[a];
for (int i = 0; i < arr.length; i++) {
arr[i]=s.nextInt();
}
show(arr);
}
static void show(int[] arr){
int[] str=new int[arr.length];
for (int i = 0; i < str.length; i++) {
System.out.println("Insert element["+(i+1)+"]:");
str[i]=arr[i];
int a=str[i];
System.out.println("Init:"+f(str,i));
if(str.length>1){
int b=i;
for (int j = str.length-1; j >=0; j--) {
if(a<str[j]){
str[b]=str[j];
System.out.println("Move back:"+f(str,i));
str[j]=a;
a=str[j];
b=j;
}
}
}
System.out.println("Final:"+f(str,i)); }
}
static String f(int[] arr,int n){
String str="";
for (int i = 0; i <= n; i++) {
str+=arr[i]+" ";
}
return str;
} }

Java实现 蓝桥杯VIP 算法提高 插入排序的更多相关文章

  1. Java实现 蓝桥杯VIP 算法提高 研究兔子的土豪

    试题 算法提高 研究兔子的土豪 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 某天,HWD老师开始研究兔子,因为他是个土豪 ,所以他居然一下子买了一个可以容纳10^18代兔子的巨大 ...

  2. Java实现 蓝桥杯VIP 算法提高 3-2求存款

    算法提高 3-2求存款 时间限制:1.0s 内存限制:256.0MB 问题描述 见计算机程序设计基础(乔林)P50第5题. 接受两个数,一个是用户一年期定期存款金额,一个是按照百分比格式表示的利率,计 ...

  3. Java实现 蓝桥杯VIP 算法提高 3-3求圆面积表面积体积

    算法提高 3-3求圆面积表面积体积 时间限制:1.0s 内存限制:256.0MB 问题描述 接受用户输⼊的数值,输出以该值为半径的(1)圆面积,(2)球体表面积,(3)球体体积.pi 取值3.1415 ...

  4. Java实现 蓝桥杯VIP 算法提高 5-3日历

    算法提高 5-3日历 时间限制:1.0s 内存限制:256.0MB 问题描述 已知2007年1月1日为星期一.设计一函数按照下述格式打印2007年以后(含)某年某月的日历,2007年以前的拒绝打印.为 ...

  5. Java实现 蓝桥杯VIP 算法提高 11-2删除重复元素

    算法提高 11-2删除重复元素 时间限制:10.0s 内存限制:256.0MB 问题描述 为库设计新函数DelPack,删除输入字符串中所有的重复元素.不连续的重复元素也要删除. 要求写成函数,函数内 ...

  6. Java实现 蓝桥杯VIP 算法提高 P0401

    算法提高 P0401 时间限制:1.0s 内存限制:256.0MB 输入一个无符号整数x,输出x的二进制表示中1的个数. 输入: 76584 输出: 7 import java.util.Scanne ...

  7. Java实现 蓝桥杯VIP 算法提高 理财计划

    算法提高 理财计划 时间限制:1.0s 内存限制:256.0MB 问题描述 银行近期推出了一款新的理财计划"重复计息储蓄".储户只需在每个月月初存入固定金额的现金,银行就会在每个月 ...

  8. Java实现 蓝桥杯VIP 算法提高 解二元一次方程组

    算法提高 解二元一次方程组 时间限制:1.0s 内存限制:256.0MB 问题描述 给定一个二元一次方程组,形如: a * x + b * y = c; d * x + e * y = f; x,y代 ...

  9. Java实现 蓝桥杯VIP 算法提高 陶陶摘苹果2

    算法提高 陶陶摘苹果2 时间限制:1.0s 内存限制:256.0MB 问题描述 陶陶家的院子里有一棵苹果树,每到秋天树上就会结出n个苹果.苹果成熟的时候,陶陶就会跑去摘苹果.陶陶有个30厘米高的板凳, ...

随机推荐

  1. 设计模式之GOF23策略

    策略模式strategy 场景:对不同客户的不同报价策略 如果采用if else不易扩展,不符合开闭原则,可以采用策略模式 策略模式: 对应于解决某一个问题的算法族,允许其中一个算法去解决某一问题,同 ...

  2. 【系列】Python编程思想(1):Python简介与开发环境搭建

    李宁老师的 开始学习.   本系列文章深入介绍了Python的各种技术,堪称是目前最全的Python教程.主要目的是让读者可以了解Python的各种核心技术,包括各种Python函数库.本教程使用Py ...

  3. iptables做nat网络地址转换

    iptables做nat网络地址转换. 0. 权威文档 http://www.netfilter.org/documentation/HOWTO/NAT-HOWTO-6.html e文好的直接跳过本文 ...

  4. 适配器模式C++实现

    目录 类适配器 对象适配器 类适配器 #include <iostream> using namespace std; // Target class Target { public: v ...

  5. HTTP响应格式

    HTTP响应格式

  6. 快速配置Samba服务

    1.安装samba 这里以CenOS 7为例,其他系统类似 yum install samba samba-client samba-common   2.修改smb.conf 最好先备份原文件,以防 ...

  7. 如何将你的node服务放到线上服务器

    最近在用node写后端数据处理,以前虽然也用node写数据来进行测试,但是一直都是处于本地使用, 今天想将node作为后端服务来处理数据, 特此,以此博客记录. 第一步,写node 接口, 在本地我们 ...

  8. 关于MYSQL 和INNODB的逻辑关系图。最好的理解是一点点动手做,观察,记录,思考。

    每隔0.1秒就刷一次MYSQL文件的变化,并闪动标示出来,以观察SQL执行时,MYSQL的处理顺序. watch -n 0.1 -d stat /var/lib/mysql/ib_logfile0 / ...

  9. Kd Tree算法详解

    kd树(k-dimensional树的简称),是一种分割k维数据空间的数据结构,主要应用于多维空间关键数据的近邻查找(Nearest Neighbor)和近似最近邻查找(Approximate Nea ...

  10. C#正则表达式基础

    namespace ---> System.Text.RegularExpressions. static void Main(string[] args) { // if (IsInputMa ...