C# Linq sum

Last modified: July 03, 2021
class Stock { public string Sku { get; set; } public string ModelName { get; set; } public string Category { get; set; } public int Qty { get; set; } } class Program { static void Main(string[] args) { var numbers = new List<int>() { 10, 4, 8,10 }; var totalSum = numbers.Sum(); //output 32 var uniqueTotalSum = numbers.Distinct().Sum(); //output 22 var fruits = new List<string>() { "Banana", "Apple", "Orange" }; var totalChars = fruits.Sum(s => s.Length); //output 17 var stock = new List<Stock>() { new Stock{Sku = "001", ModelName = "iphone11", Category = "iPhone 11", Qty = 5555 }, new Stock{Sku = "002", ModelName = "iphone11 pro", Category = "iPhone 11", Qty = 44 }, new Stock{Sku = "003", ModelName = "iphone11 pro max", Category = "iPhone 11", Qty = 100 }, new Stock{Sku = "004", ModelName = "iphone12", Category = "iPhone 12", Qty = 55 }, new Stock{Sku = "005", ModelName = "iphone12 pro", Category = "iPhone 12", Qty = 44 }, new Stock{Sku = "006", ModelName = "iphone12 pro max", Category = "iPhone 12", Qty = 10 }, }; var categories = (from c in stock group c by c.Category into d select (Category: d.Key, TotalStock: d.Sum(s => s.Qty))); //output iPhone 11: 5699 and iPhone 12: 109 } }