1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/js/src/devtools/jint/sunspider/access-binary-trees.js Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,56 @@ 1.4 +/* The Great Computer Language Shootout 1.5 + http://shootout.alioth.debian.org/ 1.6 + contributed by Isaac Gouy */ 1.7 + 1.8 +function TreeNode(left,right,item){ 1.9 + this.left = left; 1.10 + this.right = right; 1.11 + this.item = item; 1.12 +} 1.13 + 1.14 +TreeNode.prototype.itemCheck = function(){ 1.15 + if (this.left==null) return this.item; 1.16 + else return this.item + this.left.itemCheck() - this.right.itemCheck(); 1.17 +} 1.18 + 1.19 +function bottomUpTree(item,depth){ 1.20 + if (depth>0){ 1.21 + return new TreeNode( 1.22 + bottomUpTree(2*item-1, depth-1) 1.23 + ,bottomUpTree(2*item, depth-1) 1.24 + ,item 1.25 + ); 1.26 + } 1.27 + else { 1.28 + return new TreeNode(null,null,item); 1.29 + } 1.30 +} 1.31 + 1.32 +var ret; 1.33 + 1.34 +/* BEGIN LOOP */ 1.35 +for ( var n = 4; n <= 7; n += 1 ) { 1.36 + var minDepth = 4; 1.37 + var maxDepth = Math.max(minDepth + 2, n); 1.38 + var stretchDepth = maxDepth + 1; 1.39 + 1.40 + var check = bottomUpTree(0,stretchDepth).itemCheck(); 1.41 + 1.42 + var longLivedTree = bottomUpTree(0,maxDepth); 1.43 + /* BEGIN LOOP */ 1.44 + for (var depth=minDepth; depth<=maxDepth; depth+=2){ 1.45 + var iterations = 1 << (maxDepth - depth + minDepth); 1.46 + 1.47 + check = 0; 1.48 + /* BEGIN LOOP */ 1.49 + for (var i=1; i<=iterations; i++){ 1.50 + check += bottomUpTree(i,depth).itemCheck(); 1.51 + check += bottomUpTree(-i,depth).itemCheck(); 1.52 + } 1.53 + /* END LOOP */ 1.54 + } 1.55 + /* END LOOP */ 1.56 + 1.57 + ret = longLivedTree.itemCheck(); 1.58 +} 1.59 +/* END LOOP */