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

本文介绍了一种通过Java实现的一维数组中最大值与首个元素、最小值与末尾元素交换位置的方法。程序首先接收用户输入的一维数组,然后找出数组中的最大值和最小值,并进行相应的元素交换,最后输出交换后的数组。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//输入一个一维数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
import java.util.Scanner;
public class exchange{
public static void main(String args[]){
System.out.println("请输入一个一维数组:");
Scanner input=new Scanner(System.in);
//int n=input.nextInt();
int n=5;
int num[]=new int[n];
for(int i=0;i<n;i++){
num[i]=input.nextInt();
}
int max=num[0];
int t=0;
for(int j=1;j<n;j++){
if(max<num[j])
{
max=num[j];
t=j;}
}
num[t]=num[0];
num[0]=max;


int min=num[n-1];
int m=0;
for(int j=0;j<n-1;j++){
if(min>num[j]){
min=num[j];
m=j;}
}

num[m]=num[n-1];
num[n-1]=min;

for(int p=0;p<n;p++){
System.out.println(num[p]);
}


   

在Java中,你可以通过以下几个步骤创建一个一维数组交换最大元素第一个元素,以及最小元素最后一个元素: 1. **创建数组**: 首先,你需要确定数组的大小和数据类型。例如,假设我们有一个整型数组 `int[] arr`。 ```java int size = 5; // 数组长度 int[] arr = new int[size]; // 创建一个可以存储size个元素一维数组 ``` 2. **初始化数组**: 将一些赋给数组元素。这里为了展示如何操作,我们可以手动输入或随机生成初始。 ```java for (int i = 0; i < size; i++) { arr[i] = i; // 示例:将0到size-1的数字放入数组 } ``` 3. **找到最大最小元素**: 使用遍历找出最大最小元素的索引。 ```java int maxIndex = 0, minIndex = 0; for (int i = 1; i < size; i++) { if (arr[i] > arr[maxIndex]) { maxIndex = i; } if (arr[i] < arr[minIndex]) { minIndex = i; } } ``` 4. **交换元素**: 最后,用找到的最大元素替换第一个元素,用找到的最小元素替换最后一个元素。 ```java int tempMax = arr[maxIndex]; arr[maxIndex] = arr[0]; // 交换最大元素第一个元素 tempMin = arr[minIndex]; arr[minIndex] = arr[size - 1]; // 交换最小元素最后一个元素 ``` 完整示例: ```java public class Main { public static void main(String[] args) { int size = 5; int[] arr = {0, 2, 1, 4, 3}; // 示例数组,实际应用中请自行填充 // 找出最大最小元素,并交换 int maxIndex = 0, minIndex = 0; for (int i = 1; i < size; i++) { if (arr[i] > arr[maxIndex]) { maxIndex = i; } if (arr[i] < arr[minIndex]) { minIndex = i; } } int temp = arr[0]; arr[0] = arr[maxIndex]; arr[maxIndex] = temp; temp = arr[size - 1]; arr[size - 1] = arr[minIndex]; arr[minIndex] = temp; // 输出结果 System.out.println("数组元素: " + Arrays.toString(arr)); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值