Java数组排序基础算法,二维数组,排序时间计算,随机数产生

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();
		}

	}
}
时间: 2024-12-09 22:14:02

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

[Python] 专题五.列表基础知识 二维list排序、获取下标和处理txt文本实例

        通常测试人员或公司实习人员需要处理一些txt文本内容,而此时使用Python是比较方便的语言.它不光在爬取网上资料上方便,还在NLP自然语言处理方面拥有独到的优势.这篇文章主要简单的介绍使用Python处理txt汉字文字.二维列表排序和获取list下标.希望文章对你有所帮助或提供一些见解~ 一. list二维数组排序         功能:已经通过Python从维基百科中获取了国家的国土面积和排名信息,此时需要获取国土面积并进行排序判断世界排名是否正确.         列表基础

使用java从excel读取二维数组过程中报错

问题描述 代码如下,主要是做一些统计:问题应该处在从excel读取的过程中,没有飘红,但是编译时还是报错囧--希望大家帮忙看下,不甚感激--packagesy2;importjxl.*;importjxl.read.biff.*;importjava.io.*;importjava.io.File;publicclassStatistics{publicvoidQuickSort(double[]pData,intleft,intright)//快速排序{inti,j;doublefirst,t

php 基础有关问题二维数组求和

  php 基础问题二维数组求和 ! 数组: $a = array(array("a"=>"aa","a1"=>1,"a2"=>1),array("a"=>"bb","a1"=>2,"a2"=>2),array("a"=>"cc","a1"=>

Java中增强for循环在一维数组和二维数组中的使用方法_java

一维数组: int[] a={1,2,3}; for(int i:a) { System.out.print(i+" "); } 输出:1 2 3 二维数组: import java.util.Scanner; public class tet { public static void main(String[] args) { //int[][] b={{1,2,3},{4,5,6}};行 int[][] a=new int[5][];//必须明确行数 for(int i=0;i&l

Java基础-06.总结二维数组,面向对象

1:二维数组(理解) (1)元素是一维数组的数组.(2)格式:A:数据类型[][] 数组名 = new 数据类型[m][n];B:数据类型[][] 数组名 = new 数据类型[m][];C:数据类型[][] 数组名 = new 数据类型[][]{{...},{...},{...}};D:数据类型[][] 数组名 = {{...},{...},{...}}; /*二维数组:就是元素为一维数组的一个数组. 格式1:数据类型[][] 数组名 = new 数据类型[m][n]; m:表示这个二维数组有

PHP实现二维数组按某列进行排序的方法_php技巧

本文实例讲述了PHP实现二维数组按某列进行排序的方法.分享给大家供大家参考,具体如下: /* * 二维数组 按某列排序 * array_multisort($arr1,$arr2) * 手册 例子如下 * */ $data[] = array('volume' => 67, 'edition' => 2); $data[] = array('volume' => 86, 'edition' => 1); $data[] = array('volume' => 85, 'edi

PHP实现对二维数组某个键排序的方法_php技巧

本文实例讲述了PHP实现对二维数组某个键排序的方法.分享给大家供大家参考,具体如下: /** * 对查询结果集进行排序 * @access public * @param array $list 查询结果 * @param string $field 排序的字段名 * @param string $sortby 排序类型 (asc正向排序 desc逆向排序 nat自然排序) * @return array */ function list_sort_by($list, $field, $sort

php自定义函数实现二维数组按指定key排序的方法_php技巧

本文实例讲述了php自定义函数实现二维数组按指定key排序的方法.分享给大家供大家参考,具体如下: 二维数组官方的排序方法并不好,该函数可以进行指定key的排序,已经测试并使用,代码如下: /*二维数组按指定的键值排序*/ function array_sort($arr, $keys, $type = 'desc') { $keysvalue = $new_array = array(); foreach ($arr as $k => $v) { $keysvalue[$k] = $v[$ke

php基础篇-二维数组排序 array_multisort

原文:php基础篇-二维数组排序 array_multisort 对2维数组或者多维数组排序是常见的问题,在php中我们有个专门的多维数组排序函数,下面简单介绍下: array_multisort(array1,sorting order, sorting type,array2,array3..)是对多个数组或多维数组进行排序的函数. array1 必需.规定输入的数组. sorting order 可选.规定排列顺序.可能的值是 SORT_ASC 和 SORT_DESC. sorting t