import java.util.Arrays; //包含Arrays
import java.util.Random;

public class HelloWorld {
	public static void main(String[] args){
	//	Scanner s = new Scanner(System.in);
	//	System.out.println("请输入一个数字");
	//	int num = s.nextInt();
    //打印数组
		int []a = {10,14,2,3,9,87} ;
		sort(a);
		System.out.println(Arrays.toString(a));
		a = insertValue(a,15);
		System.out.println(Arrays.toString(a));
		int []b = {2,34,87,1,2,77,8,56,2} ;
		insertsort(b);
		System.out.println(Arrays.toString(b)) ;
		/////////////////////////////////////////
		//数组中自带的API排序接口
		int []c = {11,20,8,48,45,23,14} ;
		Arrays.sort(c);//调用sort方法,jdk自带,非常高效的算法
		System.out.println(Arrays.toString(c)) ;

		int []d = new int[1000000];
		for(int i = 0 ; i < d.length ;i++){
			Random r = new Random();
			d[i] = r.nextInt();//获取一个随机的整数
		}
		long start = System.currentTimeMillis() ;//获取当前的时间到1970开始时间相差的毫秒
		Arrays.sort(d); //对随机产生数组的元素进行排序,性能最好,运行最快
		//insertsort(d);
		//sort(d)
		long end = System.currentTimeMillis();
		System.out.println(end-start);//计算当前排序花费的时间

		//二维数组
		Two_array();
	}
	//选择排序算法
	//跟三个数交换是同样的原理
	public static void sort(int []a){
		for(int i = 0 ; i < a.length - 1 ; i++){
			for(int j = i + 1 ; j < a.length ; j++){
				if(a[i] > a[j]){
					int temp = a[i] ;
					a[i] = a[j] ;
					a[j] = temp ;
				}
			}
		}
	}
	/*
	 * a[0]和a[1]比较如果大则交换---->a[0]和a[1]中大的放入了a[1]
	 * a[1]和a[2]比较如果大则交换---->a[0],a[1],[2]中大的放入了a[2]
	 * a[2]和a[3]比较如果大则交换
	 * .....
	 * a[4]和a[5]比较如果大则交换---->最大的放入了a[5] ;
	 * -------------------------------第一轮
	 * a[0]和a[1],a[1]和a[2],a[2]和a[3],a[3]和a[4]------第二轮
	 *
	 * ...最后一轮a[0]和a[1]比较
	 */
	//冒泡排序算法
	public static void sort1(int []a){
		for(int i = 0 ; i < a.length-1 ; i++){
			for(int j = 0 ; j < a.length - 1 - i ; j++){
				if(a[j] > a[j+1]){
					int temp = a[j];
					a[j] = a[j+1];
					a[j+1] = temp ;
				}
			}
		}
	}
	//插入一个数以后自动排序--->一个已经排好序的数组,插入一个新元素
	public static int[] insertValue(int []a , int value){
		//从最后一个元素开始和value进行比较,如果比value大,这些元素都后移
		//一直到value大于数组的某个元素,那么说明value就应该放在这个元素之后
		a = Arrays.copyOf(a, a.length+1);
		//因为前面扩容了,最后一个元素为空,要最后一个元素的前一个才是
		for(int i = a.length - 2 ; i >= 0 ; i--){
			if(value < a[i])
				a[i+1] = a[i] ; //后移动
			else
				break ;
			a[i+1] = value ;
		}
		return a ;
	}
	/**
	 * a[0]作为基本量,拿出a[1]进行插入工作 a[0]和a[1]已经排好序了
	 * a[0],a[1]作为基本量 拿出a[2]进行插入工作  a[0],a[1],a[2]已经排好序了
	 * .....依次类推
	 */
	//插入排序
	public static void insertsort(int []a){
		int t , j;
		for(int i = 1 ; i < a.length ; i++){
			t = a[i];
			for(j = i-1 ; j >= 0 && t < a[j]; j--){
				a[j+1] = a[j] ;
			}
		}
	}

	public static void Two_array()
	{
		int [][] a = {
				{1,2,3,4,5},
				{6,7,8,9,10},
				{5,9,7,8,3},
		};
		int [][]b = new int[][]{{1,2,3},{4,5,6}};
		System.out.println(a.length);
		/*
		 * a中有三个一维数组
		 * 第一个a[0]
		 * ......a[1]
		 * */
		//二维数组中第二个一维数组的元素的长度
		System.out.println(a[1].length);
		//遍历第二个一维数组的长度
		for(int i = 0 ; i < a[1].length ; i++){
			System.out.print(a[1][i] + " ");
		}
		System.out.println();
		/*遍历二维数组中所有的元素*/
		for(int i = 0 ; i < a.length ;i++){
			for(int j = 0 ; j < a[1].length ; j++){
				System.out.print(a[i][j]+" ") ;
			}
			System.out.println();
		}

	}
}

Java数组排序基础算法,二维数组,排序时间计算,随机数产生的更多相关文章

  1. python3--算法基础:二维数组转90度

    python3--算法基础:二维数组转90度 [0, 1, 2, 3][0, 1, 2, 3][0, 1, 2, 3][0, 1, 2, 3] 二维数组转90度 [0, 0, 0, 0][1, 1, ...

  2. java怎么定义一个二维数组?

    java中使用 [][] 来定义二维数组 定义数组时也可同时初始化下面是一些例子float[][] numthree; //定义一个float类型的2维数组numthree=new float[5][ ...

  3. java基础编程——二维数组中的查找

    题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数 ...

  4. Java基础之二维数组的回顾

    class ArrayWork { /* * 二维数组的复习! * * 2014年4月2日 21:45:50 * * * **/ public static void main(String[] ar ...

  5. java基础之二维数组-杨辉三角

    首先呢你要知道什么是杨辉三角? 答:杨辉三角,是二项式系数在三角形中的一种几何排列. 简单的说一下就是两个未知数和的幂次方运算后的系数问题,比如(x+y)的平方=x的平方+2xy+y的平方,这样系数就 ...

  6. Java基础教程——二维数组

    二维数组 Java里的二维数组其实是数组的数组,即每个数组元素都是一个数组. 每个数组的长度不要求一致,但最好一致. // 同样有两种风格的定义方法 int[][] _arr21_推荐 = { { 1 ...

  7. Java基础(7):二维数组初始化时需要注意的问题

    二维数组可以先指定行,再指定列:但不能先指定列,再指定行 没有说明二维数组的行的个数,在定义二维数组时也可以只指定行的个数,然后再为每一行分别指定列的个数.如果每行的列数不同,则创建的是不规则的二维数 ...

  8. java基础之二维数组不定义列数

    有一种特殊的二维数组,它的行数确定,但是每行的列数不确定.这样的的数组实现方法:先创建制定行数,列数缺省的二维数组,然后对数组的每一行重新初始化.举例如下: package day5; //第二种定义 ...

  9. python-Day4-迭代器-yield异步处理--装饰器--斐波那契--递归--二分算法--二维数组旋转90度--正则表达式

    本节大纲 迭代器&生成器 装饰器  基本装饰器 多参数装饰器 递归 算法基础:二分查找.二维数组转换 正则表达式 常用模块学习 作业:计算器开发 实现加减乘除及拓号优先级解析 用户输入 1 - ...

随机推荐

  1. 优化Webpack打包速度

    1. Webpack 可以配置 externals 来将依赖的库指向全局变量,从而不再打包这个库,比如对于这样一个文件:   import React from 'react'; console.lo ...

  2. Docker安装tomcat和部署项目

    随着微服务的流行,Docker越来越流行,正如它的理念"Build, Ship, and Run Any App, Anywhere"一样,Docker提供的容器隔离技术使得开发人 ...

  3. Centos 6.5 安装 rar

    wget http://www.rarsoft.com/rar/rarlinux-x64-5.4.0.tar.gz tar -zxvf rarlinux-x64-5.4.0.tar.gz cd rar ...

  4. 用go实现常用算法与数据结构——队列(queue)

    queue 简介 队列是一种非常常见的数据结构,日常生活中也能经常看到.一个典型的队列如下图(图片来自 segmentfault): 可以看出队列和我们日常生活中排队是基本一致的.都遵循 FIFO(F ...

  5. JavaC命令不能被执行尴尬问题解决

    安装和配置环境变量都按着流程在,但在最后的检验时,发现Java   Java -version 都能运行,唯独Javac 报"不能识别命令"错误信息,下面列出我遇到一个尴尬问题 在 ...

  6. Java内存泄漏分析系列之三:jstat命令的使用及VM Thread分析

    原文地址:http://www.javatang.com 使用jstat命令 当服务器CPU100%的时候,通过定位占用资源最大的线程定位到 VM Thread: "VM Thread&qu ...

  7. 使用kprobes查看内核内部信息

    前言:使用printk打印变量等方法,是调试内核的有效方法之一,但是这种方法必须重新构建并用新内核启动,调试效率比较低.以内核模块的方式使用kprobes.jprobes,就可以在任意地址插入侦测器, ...

  8. 20160221.CCPP体系详解(0031天)

    程序片段(01):01.结构体静态数组.c+02.结构体动态数组.c 内容概要:结构体数组 ///01.结构体静态数组.c #include <stdio.h> #include < ...

  9. Android系统对话框

    Android系统对话框 效果图 2个按钮的对话框 3个按钮的对话框 自定义View的对话框 单选对话框 多选对话框 列表框 Code XML <?xml version="1.0&q ...

  10. Dynamics CRM 不同的站点地图下设置默认不同的仪表板

    CRM的默认仪表板只能设置一个,也就是说每个引用仪表板的站点地图下点开仪表板后都是看到的默认仪表板,例如我下图中的"日常维修仪表板" 那如果我要在不同的站点地图下看到的默认仪表板不 ...