1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
namespace gfoidl.Extensions
{
using System.Collections.Generic;
using System.Linq;
//-------------------------------------------------------------------------
/// <summary>
/// Erweiterungsmethoden für <see cref="IEnumerable<T>"/>
/// </summary>
public static class MyIEnumerableExtensions
{
/// <summary>
/// Entfernt Duplikate aus einem <see cref="IEnumerable<T>"/>.
/// </summary>
/// <typeparam name="T">
/// Der Typ der aufzulistenden Objekte.
/// </typeparam>
/// <param name="collection">
/// Die Auflistung.
/// </param>
/// <returns>
/// Auflistung ohne Duplikate.
/// </returns>
public static List<T> RemoveDuplicates<T>(this IEnumerable<T> collection)
{
return new HashSet<T>(collection).ToList();
}
//---------------------------------------------------------------------
/// <summary>
/// Entfernt Duplikate aus einem <see cref="IEnumerable<T>"/>.
/// </summary>
/// <typeparam name="T">
/// Der Typ der aufzulistenden Objekte.
/// </typeparam>
/// <param name="collection">
/// Die Auflistung.
/// </param>
/// <param name="comparer">
/// Die <see cref="IEqualityComparer<T>"/>-Implementierung, die
/// zum Vergleichen von Schlüsseln verwendet werden soll, oder null,
/// wenn der Standard-<see cref="EqualityComparer<T>"/> für diesen
/// Schlüsseltyp verwendet werden soll.
/// </param>
/// <returns>
/// Auflistung ohne Duplikate.
/// </returns>
public static List<T> RemoveDuplicates<T>(
this IEnumerable<T> collection,
IEqualityComparer<T> comparer)
{
return new HashSet<T>(collection, comparer).ToList();
}
//---------------------------------------------------------------------
/// <summary>
/// Entfernt Duplikate aus einem <see cref="IEnumerable<T>"/>. Die
/// Reihenfolge der Elemente wird dabei beibehalten.
/// </summary>
/// <typeparam name="T">
/// Der Typ der aufzulistenden Objekte.
/// </typeparam>
/// <param name="collection">
/// Die Auflistung.
/// </param>
/// <returns>
/// Auflistung ohne Duplikate.
/// </returns>
public static List<T> RemoveDuplicatesKeepOrder<T>(
this IEnumerable<T> collection)
{
HashSet<T> hashSet = new HashSet<T>();
List<T> result = new List<T>(collection.Count());
foreach (T item in collection)
if (hashSet.Add(item))
result.Add(item);
return result;
}
//---------------------------------------------------------------------
/// <summary>
/// Entfernt Duplikate aus einem <see cref="IEnumerable<T>"/>. Die
/// Reihenfolge der Elemente wird dabei beibehalten.
/// </summary>
/// <typeparam name="T">
/// Der Typ der aufzulistenden Objekte.
/// </typeparam>
/// <param name="collection">
/// Die Auflistung.
/// </param>
/// <param name="comparer">
/// Die <see cref="IEqualityComparer<T>"/>-Implementierung, die
/// zum Vergleichen von Schlüsseln verwendet werden soll, oder null,
/// wenn der Standard-<see cref="EqualityComparer<T>"/> für diesen
/// Schlüsseltyp verwendet werden soll.
/// </param>
/// <returns>
/// Auflistung ohne Duplikate.
/// </returns>
public static List<T> RemoveDuplicatesKeepOrder<T>(
this IEnumerable<T> collection,
IEqualityComparer<T> comparer)
{
HashSet<T> hashSet = new HashSet<T>(comparer);
List<T> result = new List<T>(collection.Count());
foreach (T item in collection)
if (hashSet.Add(item))
result.Add(item);
return result;
}
}
}
|