同性数组判断

import java.util.HashMap;
import java.util.Map;
/**
* 未做出错处理
* @author hp
*
*/
public class StringTest {

private int a[]={2,2,3,4,4,3,2,2,1};
private int b[]={2,2,3,4,4,2,3,2,5};
public static void main(String args[]){

StringTest s= new StringTest();
s.function(s.a,s.b);

}

public void function(int a[],int b[]){

Utils u=new Utils();
if(a.length!=b.length)//判断  两个数组不等长,直接排除
System.out.println("非同性");
else

if(u.function(a).equals(u.function(b)))
System.out.println("是同性");
else System.out.println("非同性");
}
}


/**
*
* 工具类   遍历出各个元素及个数  存放在map中 
*
*/
class Utils{ 

public HashMap function(int arr[]){
Map map=new HashMap();
int value0=0,value1=0;int value2=0; int value3=0; int value4=0; int value5=0;
int value6=0; int value7=0; int value8=0; int value9=0;
for(int i=0;i<arr.length;i++){
if(arr[i]==0){
value0++;
map.put(0, value0);
}
else if(arr[i]==1){
value1++;
map.put(1, value1);
}
else if(arr[i]==2){
value2++;
map.put(2, value2);
}
else if(arr[i]==3){
value3++;
map.put(3, value3);
}
else if(arr[i]==4){
value4++;
map.put(4, value4);
}
else if(arr[i]==5){
value5++;
map.put(5, value5);
}
else if(arr[i]==6){
value6++;
map.put(6, value6);
}
else if(arr[i]==7){
value7++;
map.put(7, value7);
}
else if(arr[i]==8){
value8++;
map.put(8, value8);
}
else if(arr[i]==9){
value9++;
map.put(9, value9);
}
}
return (HashMap) map;
}
}

你可能感兴趣的:(数组)