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

简介: import java.util.Arrays; //包含Arraysimport java.util.Random;public class HelloWorld { public static void main(String[] args){ // Scanner s = new Scanner(System.
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();
		}
		
	}
}

目录
相关文章
|
8月前
|
机器学习/深度学习 Java 编译器
解锁硬件潜能:Java向量化计算,性能飙升W倍!
编译优化中的机器相关优化主要包括指令选择、寄存器分配、窥孔优化等,发生在编译后端,需考虑目标平台的指令集、寄存器、SIMD支持等硬件特性。向量化计算利用SIMD技术,实现数据级并行,大幅提升性能,尤其适用于图像处理、机器学习等领域。Java通过自动向量化和显式向量API(JDK 22标准)支持该技术。
351 4
|
7月前
|
算法 机器人
基于SOA海鸥优化算法的PID控制器最优控制参数计算matlab仿真
本课题研究基于海鸥优化算法(SOA)优化PID控制器参数的方法,通过MATLAB仿真对比传统PID控制效果。利用SOA算法优化PID的kp、ki、kd参数,以积分绝对误差(IAE)为适应度函数,提升系统响应速度与稳定性。仿真结果表明,SOA优化的PID控制器在阶跃响应和误差控制方面均优于传统方法,具有更快的收敛速度和更强的全局寻优能力,适用于复杂系统的参数整定。
|
8月前
|
存储 缓存 Java
Java数组全解析:一维、多维与内存模型
本文深入解析Java数组的内存布局与操作技巧,涵盖一维及多维数组的声明、初始化、内存模型,以及数组常见陷阱和性能优化。通过图文结合的方式帮助开发者彻底理解数组本质,并提供Arrays工具类的实用方法与面试高频问题解析,助你掌握数组核心知识,避免常见错误。
|
11月前
|
算法 JavaScript 数据安全/隐私保护
基于GA遗传优化的最优阈值计算认知异构网络(CHN)能量检测算法matlab仿真
本内容介绍了一种基于GA遗传优化的阈值计算方法在认知异构网络(CHN)中的应用。通过Matlab2022a实现算法,完整代码含中文注释与操作视频。能量检测算法用于感知主用户信号,其性能依赖检测阈值。传统固定阈值方法易受噪声影响,而GA算法通过模拟生物进化,在复杂环境中自动优化阈值,提高频谱感知准确性,增强CHN的通信效率与资源利用率。预览效果无水印,核心程序部分展示,适合研究频谱感知与优化算法的学者参考。
|
7月前
|
Java
Java 数组学习笔记
本文整理Java数组常用操作:遍历、求和、查找、最值及二维数组行求和等典型练习,涵盖静态初始化、元素翻倍、去极值求平均等实例,帮助掌握数组基础与应用。
|
9月前
|
自然语言处理 Java Apache
在Java中将String字符串转换为算术表达式并计算
具体的实现逻辑需要填写在 `Tokenizer`和 `ExpressionParser`类中,这里只提供了大概的框架。在实际实现时 `Tokenizer`应该提供分词逻辑,把输入的字符串转换成Token序列。而 `ExpressionParser`应当通过递归下降的方式依次解析
459 14
|
9月前
|
监控 Java API
Java语言按文件创建日期排序及获取最新文件的技术
这段代码实现了文件创建时间的读取、文件列表的获取与排序以及获取最新文件的需求。它具备良好的效率和可读性,对于绝大多数处理文件属性相关的需求来说足够健壮。在实际应用中,根据具体情况,可能还需要进一步处理如访问权限不足、文件系统不支持某些属性等边界情况。
413 14
|
9月前
|
存储 Java 索引
java 数组
在 Java 中,数组是一种数据结构,用于存储多个相同类型的数据元素。数组的大小一旦创建后就不能改变,因此它是固定长度的。Java 数组是一种 对象,即使它存储的值是基本类型(如 int、double 等),它也是一个对象引用。
217 0
|
人工智能 Java
Java 中数组Array和列表List的转换
本文介绍了数组与列表之间的相互转换方法,主要包括三部分:1)使用`Collections.addAll()`方法将数组转为列表,适用于引用类型,效率较高;2)通过`new ArrayList&lt;&gt;()`构造器结合`Arrays.asList()`实现类似功能;3)利用JDK8的`Stream`流式计算,支持基本数据类型数组的转换。此外,还详细讲解了列表转数组的方法,如借助`Stream`实现不同类型数组间的转换,并附带代码示例与执行结果,帮助读者深入理解两种数据结构的互转技巧。
935 1
Java 中数组Array和列表List的转换
下一篇
开通oss服务