在本实验中,您将创建一个合并两个非负(等于或大于 0)整数数组的程序。您的程序将接受每个数组作为来自键盘的输入。您无法提前知道将输入多少个值,但您可以假设每个数组的最大长度为 10,000 个元素。要停止输入值,请输入一个负数。您可以忽略输入的任何负数并且不将它们存储在数组中。两个输入数组的元素应按升序排列。换句话说,每个数组元素的值必须大于或等于前一个元素的值。数组可能包含重复的元素。输入两个数组后,您的程序必须检查以确保每个数组的元素已按顺序输入。如果发现乱序元素,打印消息“错误:数组顺序不正确”。您的任务是将两个输入数组合并为一个新数组,所有元素按顺序排列,从最低到最高。打印出每个输入的原始数组,然后是合并的数组。请注意,您的程序必须输出每个数字之间恰好有一个空格的数组。Sample Run 1:输入第一个数组的值,最多 10000 个值,输入负数退出
3 3 5 6 8 9 -1
输入第二个数组的值,最多10000个值,输入负数退出
3 4 5 6 -5
第一个数组:
3 3 5 6 8 9
第二个数组:
3 4 5 6
合并数组:
3 3 3 4 5 5 6 6 8 9
Sample Run 2:输入第一个数组的值,最多10000个值,输入负数退出
4 5 7 2 -1
输入第二个数组的值,最多10000个值,输入负数退出
3 3 3 3 3 3 -100
第一个数组:
4 5 7 2
第二个数组:
3 3 3 3 3 3
错误:数组的顺序不正确
import java.io.*;
import static java.lang.System.*;
import java.util.Scanner;
import java.lang.Math;
import java.lang.Object;
import java.util.Arrays;
import java.util.ArrayList;
import org.apache.commons.lang3.ArrayUtils;
class Main
{
public static void main (String str[]) throws IOException {
{
Scanner scan = new Scanner(System.in);
int[] arrayone = new int[10000];
int[] arraytwo = new int[10000];
int [] mergeQ = new int[arrayone.length + arraytwo.length];
int integers = 0;
int inte = 0;
System.out.println("\nEnter the values for the first array, up to 10000 values, enter a negative number to quit");
for (int i = 0; i < arrayone.length; i++)
{
arrayone[i] = scan.nextInt();
if (arrayone[i] < 0){
break;
} else {integers ++;}
}
System.out.println("\nEnter the values for the second array, up to 10000 values, enter a negative number to quit");
for (int i=0; i<arraytwo.length; i++)
{
arraytwo[i] = scan.nextInt();
if (arraytwo[i] < 0)
{
break;
} {inte ++;}
}
System.out.println("First Array:");
for (int i=0; i< integers; i++)
{
System.out.print(arrayone[i] + " ");
}
System.out.println("\nSecond Array:");
for (int i=0; i< inte; i++)
{
System.out.print(arraytwo[i] + " ");
}
System.out.println("\nMerged Array:");{
String[] both = ArrayUtils.addAll(arrayone[integer], arraytwo[inte]);
Arrays.sort(both);
}
}
}
}