mirror of
https://github.com/dart-lang/sdk
synced 2024-11-02 14:27:18 +00:00
8fd6d0aafd
Committed: https://code.google.com/p/dart/source/detail?r=19755 Reverted: http://code.google.com/p/dart/source/detail?r=19756 Review URL: https://codereview.chromium.org//12212016 git-svn-id: https://dart.googlecode.com/svn/branches/bleeding_edge/dart@20996 260f80e4-7a28-3924-810f-c04153c831b5
22 lines
576 B
Dart
22 lines
576 B
Dart
// Copyright (c) 2011, 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 version of two-argument Ackermann-Peter function.
|
|
|
|
import "package:expect/expect.dart";
|
|
|
|
class AckermannTest {
|
|
static ack(m, n) {
|
|
return m == 0 ?
|
|
n + 1 : ((n == 0) ?
|
|
ack(m - 1, 1) : ack(m - 1, ack(m, n - 1)));
|
|
}
|
|
|
|
static testMain() {
|
|
Expect.equals(253, ack(3, 5));
|
|
}
|
|
}
|
|
|
|
main() {
|
|
AckermannTest.testMain();
|
|
}
|