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));
}
}
输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
©著作权归作者所有,转载或内容合作请联系作者
禁止转载,如需转载请通过简信或评论联系作者。
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 在日常使用中,我们经常需要用到随机数模块。在循环中,rd.Next()会由于默认的时间间隔太小而产生出重复随机数,...