Einzelnen Beitrag anzeigen

Dax
(Gast)

n/a Beiträge
 
#2

Re: Rangliste anhand eines Feldes eines Objekts sortieren.

  Alt 17. Okt 2006, 12:45
Nun, IComparable ist schnell implementiert

Code:
class YourClass : IComparable
{
  int CompareTo(object obj)
  {
    YourClass victim = obj as YourClass;
    if(victim == null) {
      // Fehler! obj ist keine YourClass
    }
    if(points == victim.points) {
      return 0;
    } else if(points < victim.points) {
      return -1;
    } else {
      return 1;
    }
  }

  int points;
}
Das ganze gibts natürlich auch generisch:Nun, IComparable ist schnell implementiert

Code:
class YourClass : IComparable<int> // der Typ von points eben
{
  int CompareTo(int obj)
  {
    if(points == victim.points) {
      return 0;
    } else if(points < victim.points) {
      return -1;
    } else {
      return 1;
    }
  }

  int points;
}
Jetzt kannst du dein Array einfach in Array.Sort reinwerfen und schon wird dein Array nach Punkten sortiert.

Dazu das SDK zu IComparable.CompareTo():

Zitat:
Parameters
obj
An object to compare with this instance.



Return Value
A 32-bit signed integer that indicates the relative order of the objects being compared. The return value has these meanings:
Value
Meaning

Less than zero
This instance is less than obj.

Zero
This instance is equal to obj.

Greater than zero
This instance is greater than obj.
Wenn du das nicht magst, brauchst du eine Klasse, die IComparer implementiert. CompareTo hat dort zwei Parameter und heißt Compare, aber im Grunde ist es das selbe - du musst Array.Sort nur eben sagen, den Comparer zu benutzen:
Code:
Array.Sort(myArray, new PointsComparer());
Ebenso gibts bei IComparer generische Varianten.

Hoffe das hilft dir
  Mit Zitat antworten Zitat