「Aの学生」のリストと「Bの学生」のリストがあるとします。次に、両方のリストを「学生」と呼ばれるより一般的なリストに追加します。次に、誰かが「AStudents」の重複リストを一般的な「students」リストに追加して私たちの生活を複雑にすることにしました。「A学生」の重複リストの1つを削除する最も効率的な方法は何ですか?2つのカスタムクラスが関係していることに注意してください。
コード内の一般的な学生リストはlstStudentsと呼ばれます。これは、重複を削除したいリストです。
(私はより良い例を考え出そうとしましたが、これは私が今できる最善のことです。)
LINQを使用する必要はありませんが、使用できます。MoreLinqも利用できます。
これが私のクラスです:
public class Student
{
public Student(string _name, int _age, Exam _lastExam)
{
name = _name;
age = _age;
lastExam = _lastExam;
}
public string name { get; set; }
public int age { get; set; }
public Exam lastExam { get; set; }
}
public class Exam
{
public Exam(int _correct, int _possible)
{
correct = _correct;
possible = _possible;
}
public int correct { get; set; }
public int possible { get; set; }
}
そして、これが混乱を作成するためのコードです:
List<List<Student>> lstStudents = new List<List<Student>>();
List<Student> lstAStudents = new List<Student>();
List<Student> lstDuplicateAStudents = new List<Student>();
List<Student> lstBStudents = new List<Student>();
// Create a list of some A students
lstAStudents.Add(new Student("Alex", 14, new Exam(98,100)));
lstAStudents.Add(new Student("Kim", 13, new Exam(96, 100)));
lstAStudents.Add(new Student("Brian", 14, new Exam(92, 100)));
lstStudents.Add(lstAStudents);
// Create a duplicate list of A students
lstDuplicateAStudents.Add(new Student("Alex", 14, new Exam(98, 100)));
lstDuplicateAStudents.Add(new Student("Kim", 13, new Exam(96, 100)));
lstDuplicateAStudents.Add(new Student("Brian", 14, new Exam(92, 100)));
lstStudents.Add(lstDuplicateAStudents);
// Create a list of some B students
lstBStudents.Add(new Student("John", 13, new Exam(88, 100)));
lstBStudents.Add(new Student("Jenny", 13, new Exam(80, 100)));
lstBStudents.Add(new Student("Jamie", 15, new Exam(81, 100)));
lstStudents.Add(lstBStudents);