sunspider-access-fannkuch.js 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /* The Great Computer Language Shootout
  2. http://shootout.alioth.debian.org/
  3. contributed by Isaac Gouy */
  4. function fannkuch(n) {
  5. var check = 0;
  6. var perm = Array(n);
  7. var perm1 = Array(n);
  8. var count = Array(n);
  9. var maxPerm = Array(n);
  10. var maxFlipsCount = 0;
  11. var m = n - 1;
  12. for (var i = 0; i < n; i++) perm1[i] = i;
  13. var r = n;
  14. while (true) {
  15. // write-out the first 30 permutations
  16. if (check < 30){
  17. var s = "";
  18. for(var i=0; i<n; i++) s += (perm1[i]+1).toString();
  19. check++;
  20. }
  21. while (r != 1) { count[r - 1] = r; r--; }
  22. if (!(perm1[0] == 0 || perm1[m] == m)) {
  23. for (var i = 0; i < n; i++) perm[i] = perm1[i];
  24. var flipsCount = 0;
  25. var k;
  26. while (!((k = perm[0]) == 0)) {
  27. var k2 = (k + 1) >> 1;
  28. for (var i = 0; i < k2; i++) {
  29. var temp = perm[i]; perm[i] = perm[k - i]; perm[k - i] = temp;
  30. }
  31. flipsCount++;
  32. }
  33. if (flipsCount > maxFlipsCount) {
  34. maxFlipsCount = flipsCount;
  35. for (var i = 0; i < n; i++) maxPerm[i] = perm1[i];
  36. }
  37. }
  38. while (true) {
  39. if (r == n) return maxFlipsCount;
  40. var perm0 = perm1[0];
  41. var i = 0;
  42. while (i < r) {
  43. var j = i + 1;
  44. perm1[i] = perm1[j];
  45. i = j;
  46. }
  47. perm1[r] = perm0;
  48. count[r] = count[r] - 1;
  49. if (count[r] > 0) break;
  50. r++;
  51. }
  52. }
  53. }
  54. startTest("sunspider-access-fannkuch");
  55. var ret;
  56. test( "Pfannkuchen", function(){
  57. ret = fannkuch(7);
  58. });
  59. endTest();