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()会由于默认的时间间隔太小而产生出重复随机数,...
- 如今,猪肉贵如金子,让人吃不起。在没有猪肉可吃的时候,人们在吃什么呢?《老人与海》讲述了一个年迈的老人,独自在海上...