C# : Sort

[".0s4*0|collections;datetime-format;sort",["F@eBCDU^","IAKEBEKAKALLKANEKA","OBBOCSTUUUUTTUUUUYHDGDGDGDGDGDFOCOCBOPFOBBOOCBEWSTTUUUUTTUUUU","rwfrfy.",".NET","Array","Dictionary","List","String","2D","Async","Console","DataTable","Dates","DateTime","Enum","File","For","Foreach","Format","IEnumerable","If","IndexOf","Lambda","LINQ","Optimization","Parse","Path","Process","Property","Random","Regex","Replace","Sort","Split","Static","Substring","Switch","Tuple","While","IComparable"," allows custom sorting of objects when implemented. When a class implements this interface, we must add the public method CompareTo(T). We implement custom sorting for a class with IComparable. ","Interface ","interface","CompareTo ","compareto","Example."," Please look at the Employee class. This class implements IComparable<Employee>, which means an Employee instance can be compared with other Employee instances. The Employee class has two instance properties: Salary and Name. ","Also: ","The Employee class provides the CompareTo(Employee) method and the ToString method.","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","C# program that implements IComparable interface","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Employee : ","IComparable","<Employee>\n{\n public int Salary { get; set; }\n public string Name { get; set; }\n\n public int CompareTo(Employee other)\n {","\n // Alphabetic sort if salary is equal. [A to Z]\n ","if (this.Salary == other.Salary)\n {\n return this.Name.CompareTo(other.Name);\n }","\n // Default to salary sort. [High to low]\n ","return other.Salary.CompareTo(this.Salary);\n }\n\n public override string ToString()\n {","\n // String representation.\n ","return this.Salary.ToString() + \",\" + this.Name;\n }\n}\n\nclass Program\n{\n static void Main()\n {\n List<Employee> list = new List<Employee>();\n list.Add(new Employee() { Name = \"Steve\", Salary = 10000 });\n list.Add(new Employee() { Name = \"Janet\", Salary = 10000 });\n list.Add(new Employee() { Name = \"Andrew\", Salary = 10000 });\n list.Add(new Employee() { Name = \"Bill\", Salary = 500000 });\n list.Add(new Employee() { Name = \"Lucy\", Salary = 8000 });","\n\n // Uses IComparable.CompareTo()\n ","list.Sort();","\n\n // Uses Employee.ToString\n ","foreach (var element in list)\n {\n Console.WriteLine(element);\n }\n }\n}\n\n","Output","\n\n500000,Bill\n10000,Andrew\n10000,Janet\n10000,Steve\n8000,Lucy","CompareTo."," Look again at the CompareTo method implementation in the Employee class. The method returns int\u2014this indicates which Employee should be ordered first. In CompareTo, we want to sort by the Salary from highest to lowest. ","However: ","If Salary is equal, we want to sort alphabetically. We check for equal Salary values, and in that case sort alphabetically.","In the Main method,"," we create a List of Employee instances. Each Employee has a Name and a Salary specified. Then, we invoke the Sort method on List. This uses the IComparable<Employee> implementation we added. ","Result: ","When this program is run, the Employee instances are sorted first by Salary and then by Name.","List ","list","Reverse sorts."," What should you do if you want to sort in reverse order in the CompareTo method? For example, if you want to order the Employee instances from lowest to highest salary, you could simply reverse the order of the CompareTo expression. ","Fragment that sorts on Salary: high to low","\n\nreturn other.Salary.CompareTo(this.Salary);\n\n","Sorts on Salary: low to high","\n\nreturn this.Salary.CompareTo(other.Salary);","Alternatives."," There are alternative ways you can sort collections of objects by two properties. The easiest is probably the orderby clause in the query syntax in System.Linq. For more information on this, check out the LINQ page on this site. ","LINQ ","linq","orderby ","orderby","CompareTo and IComparable"," are often faster than LINQ and the orderby clause. The IComparable version reorders the elements in the original list, while the orderby clause will return an IEnumerable that you must copy into a new List.","List."," There are other syntax forms available for sorting the List type. You can specify the Comparison delegate in the lambda expression syntax. In this case, you do not need to implement the IComparable interface at all. ","Caution: ","This approach may be less robust and exhibit poorer object-orientation. But in many cases, it is acceptable.","Sort Tuple ","tuple","Sort List ","sort-list","Through this example program,"," we implemented the IComparable<T> interface on a class. Then we demonstrated that the List.Sort method uses this interface to sort an object collection. ","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","3679700504","data-ad-format","link","br","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()"]