用于在列表中查找最常出现的项目的方法

时间:2016-09-18 09:53:03

标签: c# list find

好的,所以我有一个关于停车场的项目。长话短说我需要一种方法来查找数据列表中最常出现的模型。任何有效的方法(使用VST 2012)

private static int FilterbyModel(string Model, List<Car> cars)


  {
        int modelCount = 0;
        List<string> Modelis = new List<string>();
        foreach (Car s in cars)
        {
            if (s.Modelis == Model)
            {
                if (!Model.Contains(s.Modelis)) 
                {
                    Modelis.Add(s.Modelis);
                    modelCount++;
                }
            }
            return modelCount;

上述方法可行,但我需要提供一个特定的模型来寻找而不是找到最常见的模型。

1 个答案:

答案 0 :(得分:4)

计算出现次数的最简单方法是按模型分组,然后计算每个组的元素。这里我举一个LINQ的例子:

var carsByModel = cars.GroupBy(x => x.Model)
    .Select(x => new { Model = x.Key, Count = c.Count() });

现在,如果您想订购它们并选择最常见的一个:

var mostCommonCar = carsByModel.OrderByDescending(x => x.Count).First();

例如,如果您需要打印两种最常见的模型:

foreach (var model in carsByModel.OrderByDescending(x => x.Count).Take(2))
    Console.WriteLine($"{model.Model}: {model.Count}");

或者不太常见的两个人:

foreach (var model in carsByModel.OrderBy(x => x.Count).Take(2))
    Console.WriteLine($"{model.Model}: {model.Count}");

如果在那个计数中你对某个特定模型感兴趣,那么你可以这样做(注意我在这个例子中省略StringComparer但是我总是建议在生产代码):

carsByModel.First(x => x.Model.Equals("modelYouWant"));

但请注意,如果您只需要计算特定模型的出现次数,那么这会更快更简单:

int occurencesOfModelIWant = cars.Count(x => x.Model.Equals("modelYouWant"));