A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© Andyhuai 中级黑马   /  2016-3-16 22:43  /  519 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

/*
3.分析以下需求,并用代码实现:
        (1)定义一个int类型的一维数组,内容为{6,2,9,15,1,5,20,7,18}
        (2)将数组最大元素与最后一位元素进行交换,最小元素与第一位元素进行交换,并打印数组
        提示思路:先查找最大值和最小值出现的索引。
*/

class Day5_3 {
        public static void main(String[] args) {
                int [] arr ={6,2,9,15,1,5,20,7,18};
                int max = arr[0];
                int min = arr[0];
                int d =0;
                int x = 0;
                for (int i = 0; i < arr.length ;i ++ ) {                                                                //遍历出最大值和最小值
                        if (max < arr[i]) {
                                max = arr[i];
                        }else if (min > arr[i]) {
                                min = arr[i];
                        }
                }
                //根据最大值,和最小值进行搜索,找出相对应的索引值
                for (int i = 0;i < arr.length ;i++ ) {
                        if (max == arr[i]) {
                                d = i;
                        }else if (min == arr[i]) {
                                x = i;
                        }
                }
                //打印出最大值最小值以及相对应的索引
                System.out.println(max);
                System.out.println(min);
                System.out.println(d);
                System.out.println(x);
                //取得了最大值和最小值的索引,进行交换;
                int temp = arr[d];
                arr[d] = arr[arr.length -1];
                arr[arr.length-1] = temp;

                temp = arr[x];
                arr[x] = arr[0];
                arr[0] = temp;

                //打印新的数组

                for (int i = 0;  i < arr.length;i++ ) {
                        System.out.print(arr[i] + " ");
                }

        }
}
-_____________________________________________________________________________________
想要简化,不知道如何下手!

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马