79 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Java
		
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Java
		
	
	
	
| // NTAKL -- The TAKeuchi function using lists as counters,
 | |
| // rewriting the boolean expression as statements.
 | |
| 
 | |
| class Pair {
 | |
| 
 | |
|   //  A Java compiler ought to generate inline code for these.
 | |
| 
 | |
|   public static Pair cons (int n, Pair y) { return new Pair(n, y); }
 | |
|   public static int  car (Pair x) { return x.hd; }
 | |
|   public static Pair cdr (Pair x) { return x.tl; }
 | |
| 
 | |
|   //  If it doesn't, then we'll inline them by hand.
 | |
|   //  That's why the following are public.
 | |
|   //  (But Sun's Java 1.2 does the inlining ok.)
 | |
| 
 | |
|   public Pair (int n, Pair y) { hd = n; tl = y; }
 | |
|   public int hd;
 | |
|   public Pair tl;
 | |
| 
 | |
| }
 | |
| 
 | |
| class ntakl {
 | |
| 
 | |
|   static Pair listn (int n) {
 | |
|     if (n != 0)
 | |
| 	return Pair.cons (n, listn (n - 1));
 | |
|     else
 | |
|         return null;
 | |
|   }
 | |
| 
 | |
|   //  The boolean expression below comes from the original TAKL
 | |
|   //  benchmark, and remains because it is fun to see which compilers
 | |
|   //  can generate good code from it.  See NTAKL for a version in
 | |
|   //  which this mess has been cleaned up.
 | |
| 
 | |
|   static boolean shorterp (Pair x, Pair y) {
 | |
|     while ((x != null) && (y != null)) {
 | |
| 	x = Pair.cdr (x);
 | |
| 	y = Pair.cdr (y);
 | |
|     }
 | |
|     if (y == null)
 | |
| 	return false;
 | |
|     else return true;
 | |
|   }
 | |
| 
 | |
|   static Pair mas (Pair x, Pair y, Pair z) {
 | |
|     if (! shorterp (y, x))
 | |
| 	return z;
 | |
|     else
 | |
|         return mas( mas( Pair.cdr(x), y, z ),
 | |
|                     mas( Pair.cdr(y), z, x ),
 | |
|                     mas( Pair.cdr(z), x, y ) );
 | |
|   }
 | |
| 
 | |
|   static Pair l18 = listn(18);
 | |
|   static Pair l12 = listn(12);
 | |
|   static Pair l6  = listn(6);
 | |
| 
 | |
|   static int result;
 | |
| 
 | |
|   static void test_takl() {
 | |
|     result = Pair.car( mas( l18, l12, l6 ) );
 | |
|   }
 | |
| 
 | |
| /*===========================================================================*/
 | |
| 
 | |
|     public static void main (String args[])
 | |
|     {
 | |
|       int i;
 | |
| 
 | |
|       for (i=0; i<200; i++)
 | |
|         test_takl();
 | |
| 
 | |
|       if (result != 7)
 | |
|         System.out.println ("*** wrong result ***");
 | |
|     }
 | |
| 
 | |
| }
 |