◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
java 中查找两个数组中相等元素的下标,可采用以下方法:使用两个 for 循环:最直接的方法,通过嵌套循环比较元素。使用 java 8 stream:使用 stream api 过滤和查找符合条件的元素。使用 hashmap:对于元素较多的数组,使用 hashmap 存储一个数组中的元素,然后遍历另一个数组查找相等元素。
最直接的方法是使用两个 for 循环迭代数组,并在找到相等元素时记录下标:
int[] arr1 = {1, 2, 3, 4, 5}; int[] arr2 = {2, 4, 6, 8, 10}; int index1 = -1; int index2 = -1; for (int i = 0; i < arr1.length; i++) { for (int j = 0; j < arr2.length; j++) { if (arr1[i] == arr2[j]) { index1 = i; index2 = j; break; // 找到后即可跳出循环 } } if (index1 != -1) { // 在第一个数组中找到对应元素 break; // 跳出外层循环,避免重复查找 } } // 打印下标 System.out.println("arr1 的下标:" + index1); System.out.println("arr2 的下标:" + index2);
Java 8 及更高版本可以使用 Stream API 来简化查找过程:
int index1 = IntStream.range(0, arr1.length) .filter(i -> arr2[i] == arr1[i]) .findFirst() .orElse(-1); int index2 = index1 == -1 ? -1 : arr2[index1];
如果两个数组的元素较多,可以使用 HashMap 来加速查找:
Map<Integer, Integer> map = new HashMap<>(); for (int i = 0; i < arr2.length; i++) { map.put(arr2[i], i); } for (int i = 0; i < arr1.length; i++) { if (map.containsKey(arr1[i])) { index1 = i; index2 = map.get(arr1[i]); break; } }
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。