假设您可以控制如何代表成员及其朋友,我建议您这样做:
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
public class Example {
public static class Member {
String name;
public Member(String name) {
this.name = name;
}
@Override
public String toString() {
return "Member [name=" + name + "]";
}
}
public static void main(String[] args) {
Map<Member, ArrayList<Member>> members = new HashMap<>();
populateMembers(members);
System.out.println(members);
getPals(members, "Ross");
}
private static Member[] getPals(Map<Member, ArrayList<Member>> members, String name) {
if (members.get(name) != null) {
return members.get(name).toArray(new Member[members.get(name).size()]);
} else {
return new Member[] {};
}
}
private static void populateMembers(Map<Member, ArrayList<Member>> members) {
String[] names = new String[] { "Joe", "David", "Ross", "Monica", "James" };
for (int i = 0; i < names.length; i++) {
ArrayList<Member> friends = new ArrayList<>();
for (int j = i+1; j < names.length; j++) {
friends.add(new Member(names[j]));
}
members.put(new Member(names[i]), friends);
}
}
}
选项二(如果你坚持使用两个数组列表,members和memberFriends:
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
public class Example {
public static class Member {
String name;
public Member(String name) {
this.name = name;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Member other = (Member) obj;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
@Override
public String toString() {
return "Member [name=" + name + "]";
}
}
public static ArrayList<Member> members = new ArrayList<>();
public static ArrayList<ArrayList<Member>> memberFriends = new ArrayList<>();
public static void main(String[] args) {
populateMembers();
System.out.println(members);
System.out.println(memberFriends);
System.out.println(Arrays.toString(getPals("Ross")));
}
private static Member[] getPals(String name) {
int index = members.lastIndexOf(new Member(name));
if (index != -1) {
return memberFriends.get(index).toArray(new Member[memberFriends.get(index).size()]);
} else {
return new Member[] {};
}
}
private static void populateMembers() {
String[] names = new String[] { "Joe", "David", "Ross", "Monica", "James" };
for (int i = 0; i < names.length; i++) {
ArrayList<Member> friends = new ArrayList<>();
for (int j = i + 1; j < names.length; j++) {
friends.add(new Member(names[j]));
}
members.add(new Member(names[i]));
memberFriends.add(friends);
}
}
}