Traté de usar la función lambda con sort
, pero estaba obteniendo errores de "Fallo de segmentación". Me las arreglé para simplificar el código por lo siguiente:¿Debería std :: sort funcionar con la función lambda en C++ 0x/C++ 11?
#include <iostream>
#include <algorithm>
int main()
{
const int len = 18;
int intArr[len];
for (int i=0;i<len;i++) intArr[i]=1000+i;
// The following is expected to sort all but the last element of the array
std::sort(intArr, intArr + len -1, [](int a, int b)
{
std::cout<<"("<<a<<", "<<b<<")\n";
return (a<b?-1:(a>b?1:0));
});
return 0;
}
puedo compilar y ejecutar el código en Ubuntu 11.04 (x64) usando
g++ -std=gnu++0x test2.cpp && ./a.out
.
Imprime una gran cantidad de pares de la forma (large_integer, 1008), un par de (0, 1008) y sale con "Segmentation fault".
Solo como observación, solo está ordenando los primeros 17 elementos con su código. –
Sí. Este hecho se observa en el único comentario del código. – fiktor
@KerrekSB: "// Se espera que lo siguiente clasifique todo menos el último elemento de la matriz" – Griwes