好的,所以我有一个关于停车场的项目。长话短说我需要一种方法来查找数据列表中最常出现的模型。任何有效的方法(使用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;
上述方法可行,但我需要提供一个特定的模型来寻找而不是找到最常见的模型。
答案 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"));