eine Liste von structs Mit oder vielleicht ein Array-Liste mit jeweils drei Elemente haben, wieWie Elemente der Liste von Array/structs zu entfernen, die zwei gemeinsame Elemente
12 8 7
5 1 0
7 3 2
10 6 5
6 2 1
8 4 3
6 1 5
7 2 6
8 3 7
9 4 8
11 7 6
13 9 8
11 6 10
12 7 11
13 8 12
14 9 13
Ich möchte der Elemente loszuwerden, die haben 2 gemeinsame Subitems in der Liste, im Beispiel würde ich mag
5 1 0
6 2 1
6 1 5
7 3 2
7 2 6
8 4 3
8 3 7 has 2 same items as row 7,3,2
9 4 8 has 2 same items as row 8,4,3
10 6 5
11 7 6
11 6 10 has 2 same items as row 11,7,6
12 7 11 has 2 same items as row 11,7,10
12 8 7
13 8 12
13 9 8
14 9 13 has 2 same items as row 13,9,8
Also mit structs entfernen gehe ich in die Sortierung der Liste von Element A denke, dann Looping und Vergleichen Elemente, in einer Weise, dass, wenn aktuelle Element 2 Werte entsprechen einem anderen Element in der Liste. Ich füge es jedoch nicht zu einer Ergebnisliste hinzu Ich habe fest und weiß nicht, ob es einen besseren Ansatz
struct S
{
public int A;
public int B;
public int C;
}
public void test()
{
List<S> DataItems = new List<S>();
DataItems.Add(new S { A = 1, B = 2, C=3});
DataItems.Add(new S { A = 12, B = 8, C = 7 });
DataItems.Add(new S { A = 5, B = 1, C = 0 });
DataItems.Add(new S { A = 7, B = 3, C = 2 });
DataItems.Add(new S { A = 10, B = 6, C = 5 });
DataItems.Add(new S { A = 6, B = 2, C = 1 });
DataItems.Add(new S { A = 8, B = 4, C = 3 });
DataItems.Add(new S { A = 6, B = 1, C = 5 });
DataItems.Add(new S { A = 7, B = 2, C = 6 });
DataItems.Add(new S { A = 8, B = 3, C = 7 });
DataItems.Add(new S { A = 9, B = 4, C = 8 });
DataItems.Add(new S { A = 11, B = 7, C = 6 });
DataItems.Add(new S { A = 13, B = 9, C = 8 });
DataItems.Add(new S { A = 11, B = 6, C = 10 });
DataItems.Add(new S { A = 12, B = 7, C = 11 });
DataItems.Add(new S { A = 13, B = 8, C = 12 });
DataItems.Add(new S { A = 14, B = 9, C = 13 });
var sortedList = DataItems.OrderBy(x => x.A);
List<S> resultList = new List<S>();
for (int i = 0; i < sortedList.Count(); i++)
{
for (int j = i+1; j < sortedList.Count(); j++)
{
if (sortedList.ElementAt(i).A == sortedList.ElementAt(j).A || sortedList.ElementAt(i).A == sortedList.ElementAt(j).B || sortedList.ElementAt(i).A == sortedList.ElementAt(j).C)
{
//ONE HIT, WAIT OTHER
}
}
}
}
Gibt es eine effizientere Art und Weise ist die Liste zu bekommen, ohne mit 2 gleichen Elemente, die Artikel so würde ich, statt hartzucodieren die Lösung?
5 1 0
6 2 1
6 1 5
7 3 2
7 2 6
8 4 3
10 6 5
11 7 6
12 8 7
13 8 12
13 9 8
versucht, mit „Parallel.For“ sehen, wenn die Leistungssteigerung ..? – User2012384
Ok, ich verstehe es besser mit dem Schnitt, aber ich sehe immer noch keine '11,7,10' für' 12 7 11' – Plutonix