Ich überschneide eine Reihe von 100.000 Zahlen und eine Menge von 1.000 Zahlen mit set_intersection in STL und seine Einnahme von 21s, wo es 11ms in C# dauert.Warum ist set_intersection in STL so langsam?
C++ Code:
int runIntersectionTestAlgo()
{
set<int> set1;
set<int> set2;
set<int> intersection;
// Create 100,000 values for set1
for (int i = 0; i < 100000; i++)
{
int value = 1000000000 + i;
set1.insert(value);
}
// Create 1,000 values for set2
for (int i = 0; i < 1000; i++)
{
int random = rand() % 200000 + 1;
random *= 10;
int value = 1000000000 + random;
set2.insert(value);
}
set_intersection(set1.begin(),set1.end(), set2.begin(), set2.end(), inserter(intersection, intersection.end()));
return intersection.size();
}
C# Code:
static int runIntersectionTest()
{
Random random = new Random(DateTime.Now.Millisecond);
Dictionary<int,int> theMap = new Dictionary<int,int>();
List<int> set1 = new List<int>();
List<int> set2 = new List<int>();
// Create 100,000 values for set1
for (int i = 0; i < 100000; i++)
{
int value = 1000000000 + i;
set1.Add(value);
}
// Create 1,000 values for set2
for (int i = 0; i < 1000; i++)
{
int value = 1000000000 + (random.Next() % 200000 + 1);
set2.Add(value);
}
// Now intersect the two sets by populating the map
foreach(int value in set1)
{
theMap[value] = 1;
}
int intersectionSize = 0;
foreach (int value in set2)
{
int count;
if (theMap.TryGetValue(value, out count))
{
intersectionSize++;
theMap[value] = 2;
}
}
return intersectionSize;
}
}
Dies ist kein nützlicher Kommentar: Timing Sie das gesamte Programm oder nur den Aufruf von set_intersection()? – Pod
Takten Sie sowohl die Erstellung der Anfangssätze als auch die Schnittmenge? –
Sie erkennen, dass C++ std :: set eine baumbasierte Struktur ist, während das C# -Dictionary eine Array-basierte Hashtabelle ist, und List ist nur ein Array, richtig? Bevor Sie die Zuordnungsprobleme Ihres Codes berücksichtigen, vergleichen Sie Äpfel und Orangen miteinander. –