blob: b58ead3ca9a2c4218a5c4e7c8620dde2ad01c9ec [file] [log] [blame]
// Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
// @dart = 2.9
/// @assertion SplayTreeSet([int compare(E key1, E key2),
/// bool isValidKey(potentialKey)])
/// ...
/// If the compare function is omitted, it defaults to Comparable.compare, and
/// the elements must be comparable.
/// @description Checks that if the compare function is omitted, it defaults to
/// Comparable.compare
/// @author sgrekhov@unipro.ru
import "dart:collection";
import "../../../Utils/expect.dart";
class C implements Comparable {
int value;
C(this.value);
compareTo(dynamic other) {
return this.value - other.value;
}
}
main() {
SplayTreeSet set = new SplayTreeSet();
C c1 = new C(2);
C c2 = new C(1);
C c3 = new C(-1);
C c4 = new C(1);
set.add(c1);
set.add(c2);
set.add(c3);
set.add(c4);
Expect.equals(3, set.length);
Expect.equals(c3, set.elementAt(0));
Expect.equals(c2, set.elementAt(1));
Expect.equals(c1, set.elementAt(2));
}