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(); } } }
Java数组排序基础算法,二维数组,排序时间计算,随机数产生的更多相关文章
- 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, ...
- java怎么定义一个二维数组?
java中使用 [][] 来定义二维数组 定义数组时也可同时初始化下面是一些例子float[][] numthree; //定义一个float类型的2维数组numthree=new float[5][ ...
- java基础编程——二维数组中的查找
题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数 ...
- Java基础之二维数组的回顾
class ArrayWork { /* * 二维数组的复习! * * 2014年4月2日 21:45:50 * * * **/ public static void main(String[] ar ...
- java基础之二维数组-杨辉三角
首先呢你要知道什么是杨辉三角? 答:杨辉三角,是二项式系数在三角形中的一种几何排列. 简单的说一下就是两个未知数和的幂次方运算后的系数问题,比如(x+y)的平方=x的平方+2xy+y的平方,这样系数就 ...
- Java基础教程——二维数组
二维数组 Java里的二维数组其实是数组的数组,即每个数组元素都是一个数组. 每个数组的长度不要求一致,但最好一致. // 同样有两种风格的定义方法 int[][] _arr21_推荐 = { { 1 ...
- Java基础(7):二维数组初始化时需要注意的问题
二维数组可以先指定行,再指定列:但不能先指定列,再指定行 没有说明二维数组的行的个数,在定义二维数组时也可以只指定行的个数,然后再为每一行分别指定列的个数.如果每行的列数不同,则创建的是不规则的二维数 ...
- java基础之二维数组不定义列数
有一种特殊的二维数组,它的行数确定,但是每行的列数不确定.这样的的数组实现方法:先创建制定行数,列数缺省的二维数组,然后对数组的每一行重新初始化.举例如下: package day5; //第二种定义 ...
- python-Day4-迭代器-yield异步处理--装饰器--斐波那契--递归--二分算法--二维数组旋转90度--正则表达式
本节大纲 迭代器&生成器 装饰器 基本装饰器 多参数装饰器 递归 算法基础:二分查找.二维数组转换 正则表达式 常用模块学习 作业:计算器开发 实现加减乘除及拓号优先级解析 用户输入 1 - ...
随机推荐
- 解决Error: ENOENT: no such file or directory, scandir 'D:\IdeaWork\code-front-jet\node_modules\.npminstall\node-sass\3.7.0\node-sass\vendor'
在使用npm安装node-sass的时候,可能会出现如下的报错: Error: ENOENT: no such file or directory, scandir 'D:\IdeaWork\code ...
- URL重定向漏洞,python打造URL重定向漏洞检测脚本
前言: 今天学习了重定向漏洞,这个漏洞比较好理解 漏洞名:URL重定向漏洞 威胁:低 漏洞的来源:开发者对head头做好对应的过滤和限制 例子: 有漏洞的网站:http://a.com/x.php?u ...
- 2017-暑假作业-Java语言程序设计
任务列表 1.学会使用Markdown做笔记 本篇随笔就是使用的Markdown语法.养成做笔记的习惯! 参考资料: 极简MarkDown排版介绍(How to) stackedit:在线Markdo ...
- Android Studio: You need to use a Theme.AppCompat theme (or descendant) with this activity.
错误描述为: java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with ...
- Lucene总结
数据的分类 结构化数据:有固定类型或者有固定长度的数据 例如:数据库中的数据(mysql,oracle等), 元数据(就是windows中的数据) 结构化数据搜索方法: 数据库中数据通过sql语句可以 ...
- Bootstrap3 代码-程序输出
通过 <samp> 标签来标记程序输出的内容. This text is meant to be treated as sample output from a computer prog ...
- ML学习分享系列(1)_计算广告小窥[上]
原作:面包包包包包包 修改:寒小阳 && 龙心尘 时间:2016年1月 出处: http://blog.csdn.net/breada/article/details/50572914 ...
- Unity 资源管理插件
之所以写这个插件呢,就是为了方便整理项目中的资源文件,我记得之前好像也用了这么一个插件,但是也没去找,还是自己动手写一个吧,需要什么功能就看自己的需求. 在项目的过程中呢,已经写了一个插件来管理材质, ...
- SpringMVC基础配置(通过注解配置,非xml配置)
SpringMVC是什么,有多火,我这里就不再啰嗦了,SpringMVC比Struts2好用太多,我在学校的时候私下里两种都接触过,对比之后果断选择了SpringMVC,后来在做Android应用开发 ...
- Spark UI界面原理
当Spark程序在运行时,会提供一个Web页面查看Application运行状态信息.是否开启UI界面由参数spark.ui.enabled(默认为true)来确定.下面列出Spark UI一些相关配 ...