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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 小超超 中级黑马   /  2016-8-27 22:59  /  518 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

分析以下需求,并用代码实现:
        (1)定义一个int类型的一维数组,内容为{6,2,9,15,1,5,20,7,18}
        (2)将数组最大元素与最后一位元素进行交换,最小元素与第一位元素进行交换,并打印数组

2 个回复

倒序浏览
int[] arr = {6,2,9,15,1,5,20,7,18};
int max = 0;
for(int i;i < arr.length;i++){
      if(arr[max]<arr[i]){
             max = i;
      }
}
int temp = arr[max];
arr[max] = arr[arr.length-1];
arr[arr.length-1] = temp;
for(int i = 0;i<arr.length;i++){
       System.out.println(arr[i]);
}
回复 使用道具 举报
[Java] 纯文本查看 复制代码
/**
 * (1)定义一个int类型的一维数组,内容为{6,2,9,15,1,5,20,7,18}
 * (2)将数组最大元素与最后一位元素进行交换,最小元素与第一位元素进行交换,并打印数组
 * 
 * @author AnCheng
 *
 */
public class Test04 {

	public static void main(String[] args) {
		int[] arr = {6,2,9,15,1,5,20,7,18};
		//遍历输出
		System.out.println("交换前:");
		for (int i : arr) {
			System.out.print(i + " ");
		}
		int maxIndex = 0;
		int minIndex = 0;
		//遍历数组,获取最大值和最小值的下索引
		for (int i = 0; i < arr.length; i++) {
			if(arr[maxIndex] < arr[i]){
				maxIndex = i;
			}else if(arr[minIndex] > arr[i]){
				minIndex = i;
			}
		}
		
		if(maxIndex != arr.length -1){
			int t = arr[maxIndex];
			arr[maxIndex] = arr[arr.length - 1];
			arr[arr.length - 1] = t;
		}
		
		if(minIndex != 0){
			int t = arr[minIndex];
			arr[minIndex] = arr[0];
			arr[0] = t;
		}
		System.out.println("\n交换后:");
		for (int i : arr) {
			System.out.print(i + " ");
		}
	}

}
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马