输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。

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));
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
禁止转载,如需转载请通过简信或评论联系作者。

推荐阅读更多精彩内容