Customer customerOne = new Customer(\"John\", \"Doe\");
Customer customerTwo = new Customer(\"Super\", \"Man\");
Customer customerThree = new Customer(\"Crazy\", \"Guy\"
var groups = customers.GroupBy(c => c.LastName).Where(g => g.Skip(1).Any());
foreach(var group in groups) {
Console.WriteLine(group.Key);
foreach(var customer in group) {
Console.WriteLine("\t" + customer.FirstName);
}
}
Output:
Doe
John
Jane
Man
Super
Bat
You can flatten the resulting sequence of groups into one sequence with
var list = groups.SelectMany(g => g);
var result = from c in customers
join c2 in customers on c.LastName equals c2.LastName
where c != c2
select c;
customers.GroupBy(c => c.LastName).Where(g => g.Skip(1).Any()).SelectMany(c => c)
or with LINQ syntax:
var q = from c in customers
group c by c.LastName into g
where g.Skip(1).Any()
from c in g
select c;