从List <string> </string>中删除重复的元素

时间:2012-03-01 07:43:07

标签: c# winforms list

我想从List中删除重复的元素。列表中的一些元素如下所示:

Book  23
Book  22
Book  19
Notebook 22
Notebook 19
Pen 23
Pen 22
Pen 19

为了摆脱重复的元素,我已经完成了这个:

List<String> nodup = dup.Distinct().ToList();

我想保留在列表中

Book 23
Notebook 22
Pen 23

我该怎么做?

5 个答案:

答案 0 :(得分:4)

你可以做点什么

string firstElement = dup.Distinct().ToList().First();

并根据需要将其添加到另一个列表中。

答案 1 :(得分:3)

这不是100%清楚你想要的 - 但是......

如果您想在列表中保留“最大”号码,您可以这样做:

List<string> noDup = dup.Select(s => s.Split(new[] {' '}, StringSplitOptions.RemoveEmptyEntries)
        .Select(p => new { Name=p[0], Val=int.Parse(p[1]) })
        .GroupBy(p => p.Name)
        .Select(g => string.Join(" ", g.Key, g.Max().ToString()))
        .ToList();

这会通过将数字部分解析为数字,获取每个项目的最大值,并按照您指定的方式创建输出字符串来转换List<string>

答案 2 :(得分:2)

您可以将LINQ与一些String操作结合使用,按名称和MAX(Number)对所有项目进行分组:

var q = from str in list
        let Parts = str.Split(new char[] { ' ' }, StringSplitOptions.RemoveEmptyEntries)
        let item = Parts[ 0 ]
        let num = int.Parse(Parts[ 1 ])
        group new  { Name = item, Number = num } by item into Grp
        select new {
            Name  = Grp.Key,
            Value = Grp.Max(i => i.Number).ToString()
        };

var highestGroups = q.Select(g => 
    String.Format("{0} {1}", g.Name, g.Value)).ToList();

(与Reed的方法相同,但在查询语法中更易于理解)

修改:我无法重现您的评论它不起作用,这里是示例数据:

List<String> list = new List<String>();
list.Add("Book  23");
list.Add("Book  22");
list.Add("Book 19");
list.Add("Notebook  23");
list.Add("Notebook  22");
list.Add("Notebook  19");
list.Add("Pen  23");
list.Add("Pen  22");
list.Add("Pen  19");
list.Add("sheet 3");

var q = from str in list
        let Parts = str.Split(new char[] { ' ' }, StringSplitOptions.RemoveEmptyEntries)
        let item = Parts[ 0 ]
        let num = int.Parse(Parts[ 1 ])
        group new  { Name = item, Number = num } by item into Grp
        select new {
            Name  = Grp.Key,
            Value = Grp.Max(i => i.Number).ToString()
        };

var highestGroups = q.Select(g => String.Format("{0} {1}", g.Name, g.Value));
MessageBox.Show(String.Join(Environment.NewLine, highestGroups));

结果:

Book 23
Notebook 23
Pen 23
sheet 3

答案 3 :(得分:1)

您可能希望将自定义比较器添加为参数,如the example on MSDN中所示。

在这个例子中,我假设Foo是一个有两个成员的类。

class Program
{
    static void Main(string[] args)
    {
        var list = new List<Foo>()
        {
            new Foo("Book", 23),
            new Foo("Book", 22),
            new Foo("Book", 19)
        };

        foreach(var element in list.Distinct(new Comparer()))
        {
            Console.WriteLine(element.Type + " " + element.Value);
        }
    }
}

public class Foo
{
    public Foo(string type, int value)
    {
        this.Type = type;
        this.Value = value;
    }

    public string Type { get; private set; }

    public int Value { get; private set; }
}

public class Comparer : IEqualityComparer<Foo>
{
    public bool Equals(Foo x, Foo y)
    {
        if(x == null || y == null)
            return x == y;
        else
            return x.Type == y.Type;
    }

    public int GetHashCode(Foo obj)
    {
        return obj.Type.GetHashCode();
    }
}

这适用于IList,假设我们希望每个的第一个项目,而不是具有最高编号的项目。请注意不同的集合类型(例如ICollectionIEnumerable),因为它们不保证您有任何订单。因此,Foo之后的任何Distinct都可能会保留。

您还可以覆盖Equals的{​​{1}}和GetHashCode,而不是使用自定义Foo。但是,我实际上并不建议将此用于本地区别。您的班级的消费者可能无法识别IEqualityComparer的两个具有相同值的实例始终相等,无论他们是Type

答案 4 :(得分:0)

有点老式,但它应该工作, 如果我理解正确

    Dictionary<string,int> dict=new Dictionary<string,int>();

    //Split accepts 1 character ,assume each line containes key value pair seperated with spaces and not containing whitespaces
    input=input.Replace("\r\n","\n");
    string[] lines=input.Split('\n');

    //break to categories and find largest number at each 
    foreach(line in lines)
    {
        string parts[]=line.Split(' ');
        string key=parts[0].Trim();
        int value=Convert.ToInt32(parts[1].Trim());

        if (dict.ContainsKey(key))
        {
            dict.Add(key, value);
        }
        else
        {
            if (dict[key]<value)
            {
                    dict[key]=value;
            }
        }

    }


    //do somethig with dict