C# : Sort
Top 37 C# Example Pages...

["rjwsts. .3bBCCST~~}T~~YF6588465764F.BP68849646F*(BBBC*CBP595F1BC*BP5FXaBXS}T~~}T~~","Sort Dictionary."," Dictionary has no Sort method. If we need to loop through the Dictionary contents in sorted order, we must separately acquire the elements and sort them.","Sorting approaches."," We can sort a Dictionary with the Keys and Values properties and a List instance. Some approaches are slower than others.","An example."," An example Dictionary is created. We apply the Keys property on the Dictionary instance. Then we use the ToList extension method and the Sort instance method. ","ToList ","tolist","Next: ","The ToList and Sort methods are used on the Keys. The resulting List is looped through using the foreach-loop construct.","Note: ","The var implicit typed keyword is used throughout to reduce syntactic redundancy.","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","Based on:"," .NET 4.6\n\n","C# program that sorts keys in Dictionary","\n\nusing System;\nusing System.Collections.Generic;\nusing System.Linq;\n\nclass Program\n{\n static void Main()\n {","\n // Create dictionary and add five keys and values.\n ","var dictionary = new ","Dictionary","<string, int>();\n dictionary.Add(","\"car\"",", 2);\n dictionary.Add(","\"apple\"",", 1);\n dictionary.Add(","\"zebra\"",", 0);\n dictionary.Add(","\"mouse\"",", 5);\n dictionary.Add(","\"year\"",", 3);","\n\n // Acquire keys and sort them.\n ","var list = dictionary.Keys.","ToList","();\n list.","Sort","();","\n\n // Loop through keys.\n ","foreach (var key in list)\n {\n Console.WriteLine(","\"{0}: {1}\"",", key, dictionary[key]);\n }\n }\n}\n\n","Output","\n\napple: 1\ncar: 2\nmouse: 5\nyear: 3\nzebra: 0","Sort values."," This program adds keys to a Dictionary and then sorts them by their values. Dictionary instances are not initially sorted. We use the orderby keyword in a query statement. ","orderby ","orderby","C# program that sorts Dictionary","\n\nusing System;\nusing System.Collections.Generic;\nusing System.Linq;\n\nclass Program\n{\n static void Main()\n {","\n // Example dictionary.\n ","var dictionary = new Dictionary<string, int>(5);\n dictionary.Add(","\"cat\"",", 1);\n dictionary.Add(","\"dog\"",", 0);\n dictionary.Add(","\"mouse\"",", 5);\n dictionary.Add(","\"eel\"",", 3);\n dictionary.Add(","\"programmer\"",", 2);","\n\n // Order by values.\n // ... Use LINQ to specify sorting by value.\n ","var items = from pair in dictionary\n ","orderby"," pair.Value ascending\n select pair;","\n\n // Display results.\n ","foreach (KeyValuePair<string, int> pair in items)\n {\n Console.WriteLine(","\"{0}: {1}\"",", pair.Key, pair.Value);\n }","\n\n // Reverse sort.\n // ... Can be looped over in the same way as above.\n ","items = from pair in dictionary\n orderby pair.Value descending\n select pair;\n }\n}\n\n","Output","\n\ndog: 0\ncat: 1\nprogrammer: 2\neel: 3\nmouse: 5","Notes, above program."," First it declares an example Dictionary. The Dictionary keys are strings. Its values are ints. We will reorder the values to go from lowest to highest.","Notes, continued."," It accesses the KeyValuePairs in a query. It displays results, using foreach to iterate through and display each KeyValuePair. No additional lookups are required. ","LINQ ","linq","Var ","var","KeyValuePair ","keyvaluepair","Note: ","Thanks to Jon Senchyna for improving the query expression. It is more efficient to use the collection of KeyValuePairs.","OrderBy."," Another option is the OrderBy extension method in System.Linq. This approach compiles to the same code as the orderby query expression. ","Tip: ","Here the syntax is shorter. It requires only one lambda expression and method call.","Lambdas ","lambda","C# program that uses OrderBy method","\n\nusing System;\nusing System.Collections.Generic;\nusing System.Linq;\n\nclass Program\n{\n static void Main()\n {\n var items = new ","Dictionary","<int, int>();\n items.Add(-1, 0);\n items.Add(0, 1);\n items.Add(-2, 0);\n items.Add(3, 1);","\n\n // Use OrderBy method.\n ","foreach (var item in items.","OrderBy","(i ","=>"," i.Key))\n {\n Console.WriteLine(item);\n }\n }\n}\n\n","Output","\n\n[-2, 0]\n[-1, 0]\n[0, 1]\n[3, 1]","Notes, above program."," The program could, with certain changes, raise a KeyNotFoundException. You will want to trap those errors with exception handling\u2014try and catch. ","Exception ","exception","Note: ","Thanks to Even Holen for writing in with an example of the shorter OrderBy syntax form.","Tip, opposite direction."," It is possible and easy to sort in the opposite direction. Replace ascending with descending. When you omit the direction keyword, it will use ascending. ","Descending ","descending","Descending sort:","\n\nvar items = from pair in dictionary\n orderby pair.Value ","descending","\n select pair;\n\n","Output","\n\nmouse: 5\neel: 3\nprogrammer: 2\ncat: 1\ndog: 0","Notes, other methods."," Other methods I found involve more steps, code or complexity. There is nothing wrong with those methods, although they vary in efficiency.","Sort string values."," Sorting strings would work just as well. Sort() uses the interface implementations of the types. Its syntax is the same for any type that List.Sort() could sort. ","IComparable ","icomparable","A summary."," Dictionary is optimized for fast lookups, not for specific looping mechanisms. It helps in lookup-heavy programs, but hinders programs that require sorted keys. ","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","3679700504","data-ad-format","link","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","url()","url()","url()"]

["url()","url()","url()","url()","url()","url()","url()","url()","url()"]