本文介紹了如何獲得基于2個不同數組的輸出的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我在創建基于2個不同數組的輸出時遇到問題。
例如,我有兩個數組&A&Q;和&Q;B&Q;。我使用以下方法按升序對元素進行排序:
public static void sortOrder(int [] A) {
for(int i = 0; i < A.length; i++) {
for(int k = i + 1; k < A.length; k++) {
if(A[i] > A[k]) {
int temp = A[i];
A[i] = A[k];
A[k] = temp;
}
}
}
}
我想輸出數組A中的第B[i]個最小數字
例如,排序后數組A=[3,5,7,8,11,21],B為[1,3,5]。
所需的輸出為[3,7,11],因為A的第一個最小元素是3,A的第三個最小元素是7,A的第五個最小元素是11。
到目前為止,我是這么想的:
public static void Algorithm1(int [] A, int [] B) {
sortOrder(A);
sortOrder(B);
int[] result = new int[B.length];
int min = A[0];
for(int i = 0; i < A.length; i++) {
for(int k = 0; k < B.length; k++) {
if(B[k] <= min) {
result[k] = A[k];
}
}
}
System.out.println(Arrays.toString(result));
//A is [3, 5, 7, 8, 11, 21]
//B is [1, 3, 5]
//Desired output is [3, 7, 11]
}
運行此代碼,我得到的輸出為[3,5,0]。我知道問題可能出在嵌套的for循環上,但無論如何我都想不出如何解決它。如果我沒有很清楚地解釋我想要什么,很抱歉,因為我對編程仍然很陌生。
提前謝謝!!
推薦答案
您不需要有嵌套循環并遍歷兩個數組,只需循環result.length
或B.length
(因為它們始終相等)并獲取B[i] - 1
的值并將其用作訪問A
的索引。這就只剩下result[i] = A[B[i] - 1];
。
已修復代碼:
public static void Algorithm1(int [] A, int [] B) {
sortOrder(A);
sortOrder(B);
int[] result = new int[B.length];
for(int i = 0; i < result.length; i++) {
result[i] = A[B[i] - 1];
}
System.out.println(Arrays.toString(result));
}
測試運行:
public static void main(String args[]) throws Exception {
int [] arr1 = new int[]{21, 8, 11, 7, 5, 3};
int [] arr2 = new int[]{3, 5, 1};
Algorithm1(arr1, arr2);
}
輸出:
[3, 7, 11]
這篇關于如何獲得基于2個不同數組的輸出的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,