I wrote below code to compare to arrays that have same elements but in diff order.
Integer arr1[] = {1,4,6,7,2};
Integer arr2[] = {1,2,7,4,6};
For example, Above arrays are equal as they same elements 1,2,4,6,7. If you have better code for larger arrays, please share.
Edit If unique elements are taken from both the arrays and if they appear to be same, then also array should be equal. How do I write the code without using any collections classes.
Ex: arr1={1,2,3,1,2,3} arr2={3,2,1} Method should return true (=both arrays are same).
package com.test;
public class ArrayCompare {
public boolean compareArrays(Integer[] arr1, Integer[] arr2){
if(arr1==null || arr2==null){
return false;
}
if(arr1.length!=arr2.length){
return false;
}
Integer[] sortedArr1=sortArray(arr1);
Integer[] sortedArr2=sortArray(arr2);
for(int i=0;i<sortedArr1.length-1;i++){
if(sortedArr1[i]!=sortedArr2[i]){
return false;
}
}
return true;
}
public void swapElements(Integer[] arr,int pos){
int temp=arr[pos];
arr[pos]=arr[pos+1];
arr[pos+1]=temp;
}
public Integer[] sortArray(Integer[] arr){
for(int k=0;k<arr.length;k++){
for(int i=0;i<arr.length-1;i++){
if(arr[i]>arr[i+1]){
swapElements(arr,i);
}
}
}
return arr;
}
public static void main(String[] args) {
Integer arr1[] = {1,4,6,7,2};
Integer arr2[] = {1,2,7,4,6};
ArrayCompare arrComp=new ArrayCompare();
System.out.println(arrComp.compareArrays(arr1, arr2));
}
}
Do you care about duplicate counts? For example, would you need to distinguish between
{ 1, 1, 2 }and{ 1, 2, 2 }? If not, just use aHashSet:If you do care about duplicates, then either you could use a
Multisetfrom Guava.If you want to stick with the sorting version, why not use the built-in sorting algorithms instead of writing your own?
EDIT: You don’t even need to create a copy, if you’re happy modifying the existing arrays. For example:
You can also have an optimization for the case where the arrays aren’t the same length: