I want to write a sorting logic to sort the below strings as output of a custom class:
Output Now:
3m_20,2m_20,1m_20,10d_20,5d_20,0d_20,0d_0,5d_0,10d_0,1m_0,2m_0,3m_0
Required Output:
0d_0,0d_20,5d_0,5d_20,10d_0,10d_20,1m_0,1m_20,2m_0,2m_20,3m_0,3m_20
I am finding it difficult to complex to sort in the above fashion. Please help how can I sort as required ?
I have tried to sort it with the IComparable on the basis of Id but its sorting on the basis of the first character.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text.RegularExpressions;
namespace Rextester
{
public class Program
{
public static void Main(string[] args)
{
DateDefinition d1 = new DateDefinition { Horizon = "0d",Days=20};
DateDefinition d1_0 = new DateDefinition { Horizon = "0d",Days=0};
DateDefinition d2 = new DateDefinition { Horizon = "5d",Days=20};
DateDefinition d2_0 = new DateDefinition { Horizon = "5d",Days=0};
DateDefinition d3 = new DateDefinition { Horizon = "10d",Days=20};
DateDefinition d3_0 = new DateDefinition { Horizon = "10d",Days=0};
DateDefinition d4 = new DateDefinition { Horizon = "1m",Days=20};
DateDefinition d4_0 = new DateDefinition { Horizon = "1m",Days=0};
DateDefinition d5 = new DateDefinition { Horizon = "2m",Days=20};
DateDefinition d5_0 = new DateDefinition { Horizon = "2m",Days=0};
DateDefinition d6 = new DateDefinition { Horizon = "3m",Days=20};
DateDefinition d6_0 = new DateDefinition { Horizon = "3m",Days=0};
var definitions = new List<DateDefinition> {d6,d5,d4,d3,d2,d1,d1_0,d2_0,d3_0,d4_0,d5_0,d6_0};
definitions.Sort();
foreach(var d in definitions)
{
Console.WriteLine(d.Id);
}
}
}
public class DateDefinition : IComparable<DateDefinition>
{
public string Horizon { get; set; }
public int Days { get; set; }
public string Id
{
get { return Horizon + "_" + Days.ToString(); }
}
public int CompareTo(DateDefinition other)
{
if (ReferenceEquals(other, this)) return 0;
if(ReferenceEquals(other,null)) return -1;
return string.Compare(Id,other.Id, StringComparison.InvariantCultureIgnoreCase);
}
}
}
Output to the above code:
0d_0 0d_20 10d_0 10d_20 1m_0 1m_20 2m_0 2m_20 3m_0 3m_20 5d_0 5d_20
Need the output like:
0d_0 0d_20 5d_0 5d_20 10d_0 10d_20 1m_0 1m_20 2m_0 2m_20 3m_0 3m_20
Important Note: Please note that d=days , m=months in the above context.
Horizon = "5d",Days=20mean? 5d seems to imply 5 days, but then what does Days=20 mean?