查看所有50道基础算法题请看:
Java的50道基础算法题
package Demo35Max_Min_Exchange;
import java.util.Arrays;
import java.util.Scanner;
/**
* 输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
*/
/*
分析:交换数据很简单,但首先要先找到最大跟最小数字的index。
*/
public class Max_Min_Exchange {
public static void main(String[] args) {
//获取用户的输入,并解析为一个数组
Scanner sc = new Scanner(System.in);
System.out.println("请直接输入数组元素,(以逗号作为间隔)");
String str = sc.next();
//分割用户输入得到一个字符串数组
String[] strs = str.split(",|,");
// 遍历这个字符串数组,将每个字符串解析为一个Integer,并装到Integer数组中
Integer[] nums = new Integer[strs.length];
try {
for (int i = 0; i < strs.length; i++) {
nums[i] = Integer.parseInt(strs[i]);
}
}catch (NumberFormatException e){
System.out.println("你输入有误,请输入数字,其它字符不支持");
}
int max_index = 0;
int min_index = 0;
int max =nums[0];
int min =nums[0];
int bottle=0;
// 遍历数组,获取最大数和最小数对应的index值
for (int i = 0; i < nums.length; i++) {
if(max<nums[i]){
max_index=i;
max = nums[i];
}
if(min>nums[i]){
min_index=i;
min=nums[i];
}
}
// 捣鼓瓶子,倒来倒去
bottle=nums[0];
nums[0]=nums[max_index];
nums[max_index]=bottle;
bottle=nums[nums.length-1];
nums[nums.length-1]=nums[min_index];
nums[min_index]=bottle;
// 打印结果
System.out.println("===========================");
System.out.println("处理方案:最大的与第一个元素交换,最小的与最后一个元素交换");
System.out.println("您输入的数组经过处理之后的结果为:");
System.out.println(Arrays.toString(nums));
}
}