Sort a list : sort « Collections « Visual C++ .NET






Sort a list

 
#include "stdafx.h"
#include <cliext/list>

using namespace System;
using namespace cliext;
using namespace System::Collections::Generic;

ref class MyClass{
public:
    String^ Name;

    MyClass() : Name(String::Empty) { }

    MyClass(String^ name) : Name(name) { }

    MyClass(const MyClass% orig){
        Name = orig.Name; 
    }
    MyClass% operator=(const MyClass% orig){
        if (this != %orig)
            Name = orig.Name;
        return *this;
    }

    ~MyClass() { }

    bool operator<(const MyClass^ rhs){
        return (Name->CompareTo(rhs->Name) < 0);
    }

    bool operator>(const MyClass^ rhs){
        return (Name->CompareTo(rhs->Name) > 0);
    }

    bool operator==(const MyClass^ rhs){
        return (Name->Equals(rhs->Name));
    }
};

int main(array<System::String ^> ^args)
{
    list<MyClass^> pets; 
    pets.push_front(gcnew MyClass("A")); 
    pets.push_front(gcnew MyClass("B"));
    pets.push_front(gcnew MyClass("C"));
    pets.push_front(gcnew MyClass("D"));


    ICollection<MyClass^>^ genericIList = %pets;

    genericIList->Add(gcnew MyClass("E"));

  pets.sort();

    for each (MyClass^ pet in genericIList) 
        System::Console::Write("{0} ", pet->Name); 

    return (0);
}

   
  








Related examples in the same category

1.sort and functor
2.Sort list by a user-defined functor
3.Sort list by greater-functor