按字段排序,然后按C#中的另一个字段检查是否相等

时间:2018-10-18 19:00:04

标签: c# collections sortedset

我有一个这样的课程

public enum RespondantRole
{
    Operator = 0,
    Supervisor = 1, 
    Director = 2
}

public class Respondant: IComparable<Respondant>
{
    public string Name { get; set; }
    public RespondantRole Role { get; set; }

    public int CompareTo(Respondant other)
    {
        return ((int)this.Role).CompareTo((int)other.Role);
    }
}

我希望使用此类创建一个SortedSet。但我希望按角色(即操作员,主管和总监)进行订购。但是,由于不允许重复,因此我希望根据唯一的Name字段检查是否相等。

因此,当我使用下面的代码初始化此集合时,我得到正确的顺序,但是只有3个元素,因为其他三个元素在后续添加中均出现重复问题。

在唯一约束基于Name属性的情况下,该如何按角色对该集合进行排序。

public class CallCenterManager
{
    private SortedSet<Respondant> AvailableRespondants;
    public CallCenterManager()
    {
        AvailableRespondants = new ObservableSortedSet<Respondant>();
        for(int i=0; i < 10; ++i)
        {
            AvailableRespondants.Add(new Respondant() { Name = $"Operator{i}", Role = RespondantRole.Operator });
            if(i < 5)
            {
                AvailableRespondants.Add(new Respondant() { Name = $"Supervisor{i}", Role = RespondantRole.Supervisor });
            }
            if(i < 3)
            {
                AvailableRespondants.Add(new Respondant() { Name = $"Director{i}", Role = RespondantRole.Director });
            }
        }
    } 

运行上面的代码时,我在集合中得到3个条目

{ Name = "Operator0", Role = Operator} 
{ Name = "Supervisor0", Role = Supervisor}
{ Name = "Director0", Role = Director}

现在按角色级别对它进行排序,但是由于compareTo基于角色,因此不会插入具有相同角色的下一组Respondant。 即您看不到{ Name = "Operator1", Role = Operator}

所以我希望输出是

{ Name = "Operator0", Role = Operator} 
{ Name = "Operator1", Role = Operator} 
{ Name = "Operator2", Role = Operator} 
.. upto 10 entries
{ Name = "Supervisor0", Role = Supervisor}
{ Name = "Supervisor1", Role = Supervisor}
.. up to 5 entries
{ Name = "Director0", Role = Director}
.. upto 3 entries

1 个答案:

答案 0 :(得分:2)

您可以通过这种方式更改CompareTo

public int CompareTo(Respondant other)
{
    int x = ((int)this.Role).CompareTo((int)other.Role);
    if(x == 0)
        return this.Name.CompareTo(other.Name);
    else
        return x;
}

在将元素添加到SortedSet类中时,将立即将其与该类中已有的其他元素进行比较,以在内部列表中找到确切的位置以保持所有内容排序。但是,当仅使用角色进行比较时,在前三个元素之后,您将开始从CompareTo方法返回0。
SortedSet不允许重复,如果返回0,它将把此结果视为两个元素之间相等的标志,并且不会将新元素添加到其内部列表中。

顺便说一句,我认为您正在使用SortedSet类。我在类库中找不到ObservableSortedSet。