黑马程序员——数组求最大值方法
来源:互联网 发布:淘宝联盟是返利吗 编辑:程序博客网 时间:2024/06/07 15:07
数组求最大值办法
(有两种思路)
思路一:是重载方式
(就是有几种数字数组就写几个重载方法,因为Arrays中的toString()方法就是这么干的(黄玉昆给的解释,很好),毕竟基本数据类型没封装类好操作)。
代码实现:
public class GetMaxAndMin {public static void main(String[] args) {// TODO Auto-generated method stubint[] arr = new int[]{1,21,2,24,4,64,6,86,8,98,9};String max_min = getMax_Min(arr);System.out.println(max_min); //打印结果:数组中,最大值为:98 , 最小值为 :1}public static String getMax_Min(int[] arr){int max = arr[0];int min = arr[0];for(int x = 1;x<arr.length;x++){if(max<arr[x])max = arr[x];if(min>arr[x])min = arr[x];}return "数组中,最大值为:"+max+" , 最小值为 :"+min;} public static String getMax_Min(double[] arr){ double max = arr[0]; double min = arr[0];for(int x = 1;x<arr.length;x++){if(max<arr[x])max = arr[x];if(min>arr[x])min = arr[x];}return "数组中,最大值为:"+max+" , 最小值为 :"+min;} public static String getMax_Min(long[] arr){ long max = arr[0];long min = arr[0];for(int x = 1;x<arr.length;x++){if(max<arr[x])max = arr[x];if(min>arr[x])min = arr[x];}return "数组中,最大值为:"+max+" , 最小值为 :"+min; }}
思路二:是利用反射
(开始我想的也是这种,可是没有想到结合集合去解决在数组类型未知时怎么比较大小,问了下老师得到了满意的答复)
不能像这样用泛型getMax(T[]),因为T[]不接收基本类型的数组。
代码:
//这是关键:因为不确定数组的数据类型,无法用>比较大小,可以考虑是用集合工具了Collections的max()方法/* 思路:* 1、传入一个数组引用获取其字节码文件* 2、用Class的静态方法,isArray判断是不是数组* 3、是数组的话通过componentType()方法获取其数组类型* 4、对类型进行判断,是基本数据类型就一个个添加进list集合(自动装箱)* 5、不是的话就用Object中的arrayCopy(),直接添加进list集合。* 6、因为jvm不知道数组类型,所以不能用<、>比较符号,用Collections中的max,min方法获取集合中的最大值最小值* */ class GetMaxAndMin{ public static void main(String[] args){ int[] ins = {1,21,2,24,4,64,6,86,8,98,9}; double[] ds = { 123.323, 123.54, 328.0 }; float[] fs = { 123.5f, 32.4f }; Integer[] in = { 1, 2, 3, 4, 17 }; Double[] d = { 123.323, 123.54, 328.0 }; System.out.println(getMax_Min(ins)); //数组中最大值为:98, 最小值为:1 System.out.println(getMax_Min(ds)); // 数组中最大值为:328.0, 最小值为:123.323 System.out.println(getMax_Min(fs)); //数组中最大值为:123.5, 最小值为:32.4 System.out.println(getMax_Min(in)); //数组中最大值为:17, 最小值为:1 System.out.println(getMax_Min(d)); // 数组中最大值为:328.0, 最小值为:123.323 } @SuppressWarnings({ "unchecked", "rawtypes" })public static String getMax_Min(Object arr){ Class clazz = arr.getClass(); List list = new ArrayList(); int length = 0; if (clazz.isArray()) { // 判断是不是数组 length = Array.getLength(arr); Class componentType = clazz.getComponentType(); // 获得数组的类型 if (componentType == int.class || componentType == double.class || componentType == float.class || componentType == long.class) { for (int i = 0; i < length; i++) { // 如果是基本类型的数字数组,需要手动添加到集合 list.add(Array.get(arr, i)); } } else if (componentType == Integer.class || componentType == Float.class || componentType == Double.class ||componentType == Long.class) { // 如果是包装类型,用Arrays的asList()方法 Object[] newArr = (Object[]) Array.newInstance(componentType, length); System.arraycopy(arr, 0, newArr, 0, length); list = Arrays.asList(newArr); } else { throw new RuntimeException("请出入数字数组"); } } else { throw new RuntimeException("请输入数组"); } return "数组中最大值为:"+Collections.max(list)+", 最小值为:"+Collections.min(list); } }
0 0
- 黑马程序员——数组求最大值方法
- 黑马程序员—C学习笔记—数组的求最大值和反转
- 黑马程序员java学习—如何获取数组中的最大值
- 黑马程序员—数组、方法
- 递归方法求数组最大值
- 黑马程序员—方法与数组
- 类模板——求数组最大值
- OJ——对象数组求最大值
- OJ积累—对象数组求最大值
- 黑马程序员_数组取最大值
- 黑马程序员—数组
- 黑马程序员—数组
- 求数组中的最大值 —用递归算法求数组中的最大值。
- 递归方法求整型数组中最大值
- js求数组中的最大值(reduce方法)
- 用递归方法求数组的最大值
- 用递归方法求数组的最大值
- 黑马程序员——Java数组排序的常见方法
- goagent GAE平台部署教程
- 二进制、八进制、十进制、十六进制之间转换
- XML Parser 概述
- Remove Duplicates from Sorted Array II
- 51单片机定时器/计数器(2)
- 黑马程序员——数组求最大值方法
- Day1 helloos0
- cocos2d-x的常用动作API
- Android 布局中长度单位的深入研究
- 四阶魔方玩法总结V1.0
- hdu1134 Game of Connections 卡特兰数(大数)
- Core Data could not fulfill a fault
- IOS中十七个常用代码整理
- Hadoop Fair Scheduler