繁体   English   中英

C#从列表中删除重复项<string[]>

[英]C# remove duplicates from List<string[]>

我从数据库中获得了很多数据,这些数据是搜索功能的结果。 现在,我有一个List<string[]> ,它具有重复的string[]类型的元素。 列表中的string[]是搜索结果。

我知道每个新创建的数组都有一个不同的实例,所以我不能使用MyListOfArrays.Distinct().ToList()

也许这是一个非常基本的问题...

我的问题是,是否有内置函数从List<string[]>删除重复的string[] 还是我必须自己写?

谢谢

您可以对自定义的equalsComparer使用distinct方法

    IEnumerable<string[]> distinct = inputStringArrayList.Distinct(new EqualityComparer());

平等比较器

class EqualityComparer : IEqualityComparer<string[]>
{
    public bool Equals(string[] x, string[] y)
    {
        if (x.Length != y.Length)
        {
            return false;
        }
        if (x.Where((t, i) => t != y[i]).Any())
        {
            return false;
        }
        return true;
    }

    public int GetHashCode(string[] obj)
    {
        return obj.GetHashCode(); 
    }
}

替代平等法

public bool Equals(string[] x, string[] y)
{
    return x.SequenceEqual(y);
}

在这里,我假设您在相同的索引处具有完全相同的字符串数组,并且内容相同。

Matthew Watson的改正

public int GetHashCode(string[] obj)
        {
            if (obj == null)
                return 0;

            int hash = 17;

            unchecked
            {
                foreach (string s in obj)
                    hash = hash*23 + ((s == null) ? 0 : s.GetHashCode());
            }

            return hash;
        }

我已经更正了@Muctadir Dinar的答案。

(他的答案值得称赞-我只是在更正并提供完整的测试程序):

using System;
using System.Collections.Generic;
using System.Linq;

namespace Demo
{
    sealed class EqualityComparer: IEqualityComparer<string[]>
    {
        public bool Equals(string[] x, string[] y)
        {
            if (ReferenceEquals(x, y))
                return true;

            if (x == null || y == null)
                return false;

            return x.SequenceEqual(y);
        }

        public int GetHashCode(string[] obj)
        {
            if (obj == null)
                return 0;

            int hash = 17;

            unchecked
            {
                foreach (string s in obj)
                    hash = hash*23 + ((s == null) ? 0 : s.GetHashCode());
            }

            return hash;
        }
    }

    class Program
    {
        private void run()
        {
            var list = new List<string[]>
            {
                strings(1, 10), 
                strings(2, 10), 
                strings(3, 10), 
                strings(2, 10), 
                strings(4, 10)
            };

            dump(list);
            Console.WriteLine();

            var result = list.Distinct(new EqualityComparer());
            dump(result);
        }

        static void dump(IEnumerable<string[]> list)
        {
            foreach (var array in list)
                Console.WriteLine(string.Join(",", array));
        }

        static string[] strings(int start, int count)
        {
            return Enumerable.Range(start, count)
                .Select(element => element.ToString())
                .ToArray();
        }

        static void Main(string[] args)
        {
            new Program().run();
        }
    }
}

一种简单但不是非常有效的方法是使用string.Join加入string[]

list = list
.GroupBy(strArr => string.Join("|", strArr))
.Select(g => g.First())
.ToList();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM