Sobes.tech
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}");
}

Этот код группирует сотрудников по отделам, находит максимальную зарплату в каждой группе и выбирает всех сотрудников с этой зарплатой.