无限递归循环我无法解决?

时间:2014-12-05 20:39:12

标签: java recursion

我正在开发一个程序,以递归方式生成音阶中的音调频率。每个频率是比前一个频率高两个的第十二个根。该程序必须使用递归(呃,教育)。当我使用这种方法时,我只是一遍又一遍地重复初始音调。那是为什么?

public static void scale(double x, double z){
double y;
  if(z == x){
     y = z * Math.pow(2, (1/12));
     System.out.println(y);
     scale (y, y); 
   }
   else if(z >= (2 * x) - 1 || z <= (2 * x) + 1){
     y = z;
     System.out.println();
   }
   else{
     y = z * Math.pow(2, (1/12));
     scale (y, y);
   }
  System.out.println(y);
}

1 个答案:

答案 0 :(得分:6)

  

为什么?

由于Java的整数除法。具体来说,1/12变为0,而不是0.083333333,因为必须产生int。然后,2提升到权力01yz相同。

使用double文字来强制进行浮点除法。

1.0/12.0