Back to questions
Middle+
2
Требуется вывести список сотрудников, получающих максимальную заработную плату в своем отделе.
Companies where asked
СБК ПАРУС
Answer from AI
sobes.tech AI
Для вывода списка сотрудников, получающих максимальную зарплату в своем отделе, можно использовать LINQ с группировкой по отделам и выбором сотрудников с максимальной зарплатой в каждой группе.
Пример на C#:
class Employee
{
public int Id { get; set; }
public string Name { get; set; }
public string Department { get; set; }
public decimal Salary { get; set; }
}
var employees = new List<Employee>
{
new Employee { Id = 1, Name = "Иван", Department = "IT", Salary = 100000 },
new Employee { Id = 2, Name = "Мария", Department = "IT", Salary = 120000 },
new Employee { Id = 3, Name = "Петр", Department = "HR", Salary = 90000 },
new Employee { Id = 4, Name = "Ольга", Department = "HR", Salary = 90000 },
};
var topEarners = employees
.GroupBy(e => e.Department)
.SelectMany(g =>
{
var maxSalary = g.Max(e => e.Salary);
return g.Where(e => e.Salary == maxSalary);
});
foreach (var emp in topEarners)
{
Console.WriteLine($"{emp.Name} из отдела {emp.Department} с зарплатой {emp.Salary}");
}
Этот код группирует сотрудников по отделам, находит максимальную зарплату в каждой группе и выбирает всех сотрудников с этой зарплатой.