0
Я пытался написать метод, который может удалить не только объект (Пользователь) из LinkedList (allUsers), но также и из отдельных LinkedLists, которые есть у всех Пользователей. Может ли кто-нибудь объяснить мне, почему это неправильно? Я включил этот метод и класс User.Как удалить объект из LinkedList объектов и из LinkedLists всех этих объектов?
public void removeUser(User u){
//curr equal to front of users list
Node curr=allUsers.getFront();
//loop to remove friend from FriendsList
while(!curr.getNext().getData().equals(u)||curr.getNext()!=null){
curr=curr.getNext();
}
if(curr.getNext()!=null)
allUsers.remove(allUsers.indexOf(curr.getNext().getData()));
//loop to run through allUsers
curr=allUsers.getFront();
while(curr!=null){
if(curr.getData().getFriends().size()!=0){
//run through friends LinkedLists of each user
Node curr2=curr.getData().getFriends().getFront();
while(curr2!=null){
if(curr2.getData().equals(u))
curr2.getData().removeFriend(u);
curr2=curr2.getNext();
}
}
curr=curr.getNext();
}
}
Класс пользователя:
public class User{
private String name;
private String location;
private int birthYear;
private LinkedList friends;
public User(String n, String l, int b){
name=n;
location=l;
birthYear=b;
friends=new LinkedList();
}
public String getName(){return name;}
public String getLocation(){return location;}
public int getBirthYear(){return birthYear;}
public boolean equals(User u){
if(this.getName().equals(u.getName())&&this.getLocation().equals(u.getLocation())&&this.getBirthYear()==u.getBirthYear())
return true;
else
return false;
}
public LinkedList getFriends(){return friends;}
public int getNumFriends(){return friends.size();}
public String toString(){
return name+" from "+location;
}
public void addFriend(User u){friends.addToEnd(u);}
public void removeFriend(User u){
if(friends.indexOf(u)!=-1)
friends.remove(friends.indexOf(u));
}
}
, что случилось с 'allUsers.remove (и)' для первой части (I» я не уверен, что вы спрашиваете со второй частью вашего вопроса). Вы должны спроектировать его, чтобы вам не пришлось самостоятельно перебирать список, и пусть 'LinkedList' обрабатывает поиск самого подходящего объекта. – Krease