java数组元素倒序的三种方法
来源:互联网 发布:深圳软件开发工资水平 编辑:程序博客网 时间:2024/05/20 07:50
将数组元素反转有多种实现方式,这里介绍常见的三种.
- 直接数组元素对换
@Testpublic void testReverseSelf() throws Exception { System.out.println("use ReverseSelf"); String[] strings = { "ramer", "jelly", "bean", "cake" }; System.out.println("\t" + Arrays.toString(strings)); for (int start = 0, end = strings.length - 1; start < end; start++, end--) { String temp = strings[end]; strings[end] = strings[start]; strings[start] = temp; } System.out.println("\t" + Arrays.toString(strings));}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 使用ArrayList: ArrayList存入和取出的顺序是一样的,可以利用这里特性暂时存储数组元素.
@Testpublic void testArrayList() throws Exception { System.out.println("use ArrayList method"); String[] strings = { "ramer", "jelly", "bean", "cake" }; System.out.println("\t" + Arrays.toString(strings)); List<String> list = new ArrayList<>(strings.length); for (int i = strings.length - 1; i >= 0; i--) { list.add(strings[i]); } strings = list.toArray(strings); System.out.println("\t" + Arrays.toString(strings));}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 使用Collections和Arrays工具类
@Testpublic void testCollectionsReverse() throws Exception { System.out.println("use Collections.reverse() method"); String[] strings = { "ramer", "jelly", "bean", "cake" }; System.out.println("\t" + Arrays.toString(strings)); // 这种方式仅针对引用类型,对于基本类型如: // char[] cs = {'a','b','c','g','d'}; // 应该定义或转换成对应的引用类型: // Character[] cs = {'a','b','c','g','d'}; Collections.reverse(Arrays.asList(strings)); System.out.println("\t" + Arrays.toString(strings));}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 速度测试:
@Testpublic void testTimeDuration() throws Exception { recordTime(ArrayReverse.class,"testCollectionsReverse"); recordTime(ArrayReverse.class,"testArrayList"); recordTime(ArrayReverse.class,"testReverseSelf");}private static String[] strings = new String[1000000];{ for (int i = 0; i < 1000000; i++) { strings[i] = String.valueOf(i); }}/** * 记录操作执行总时间. * * @param <T> the generic type * @param clazz the clazz * @param methodName the method name */public <T> void recordTime(Class<T> clazz, String methodName) { long start = System.currentTimeMillis(); System.out.println("start: " + start); Method[] declaredMethods = clazz.getDeclaredMethods(); for (Method method : declaredMethods) { String name = method.getName(); if (name.equals(methodName)) { try { method.invoke(clazz.newInstance()); } catch (Exception e) { e.printStackTrace(); } } } long end = System.currentTimeMillis(); System.out.println("end: " + end); System.out.println("duration: " + (end - start) + " ms");}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
测试结果:
使用Collections和Arrays工具类: 12 ms
使用ArrayList: 7 ms
直接数组元素对换: 4 ms
当数据量越来越大时,使用ArrayList的方式会变得很慢.
直接使用数组元素对换,总是最快完成.总结: 使用Collections和Arrays工具类反转数组元素更简单,但是在原数组上操作时速度更快,并且占用最少的内存.
阅读全文
0 0
- java数组元素倒序的三种方法
- Java 数组元素倒序的三种方式
- Java 数组元素倒序的三种方式
- java 数组元素倒序输出
- 通过分类为数组元素添加一个倒序的方法.
- 访问数组元素的三种方法
- 数组元素倒序
- MATLAB数组元素引用的三种方法
- 通过分类为数组添加一个倒序的一个方法. 比如: 数组中元素为 @”aa”, @”bb”, @”cc”, @”dd”, @”ee”, 倒序完之后为: @”ee”, @”dd”,@”cc”,@”bb”,@
- iOS 数组倒序方法
- java创建数组的三种方法
- java 创建数组的三种方法
- java创建数组的三种方法
- java创建数组的三种方法
- java创建数组的三种方法
- Java输出数组的三种方法
- java 创建数组的三种方法
- Java实现字符串倒序输出的几种方法
- word2vec浅析
- 【备忘】使用 Docker Machine 创建虚拟机的脚本及参数
- BootStrap 模态框禁用ESC关闭、禁用点击空白处关闭
- Android进阶之路
- Swift-使用 R.swift 优雅的使用资源文件
- java数组元素倒序的三种方法
- Nginx + uwsgi + Django 简单上线配置
- weblogic项目可以没有web.xml文件?
- js学习笔记
- 如何在predix上构建使用postgresql服务的Java Webapp
- FTP连接图片上传工具类
- python 位运算
- tomcat部署项目方式
- 如何解决电脑无法访问个别网站