通过二进制搜索帮助递归(Java)

时间:2019-02-01 18:50:40

标签: java recursion binary binary-search

我们被告知使用递归类进行二进制搜索。但是我被卡住了,因为根据我的教授的说法,递归不能正常工作(当我寻求帮助时没有详细说明),并且一直在和一位同学一起工作。我们得出需要int计数的结论,但是我不确定在哪里或如何实现它。 Java不是我最强的语言,因此指南或提示将非常有帮助。

            public class Recursive {
            public int BinarySearch(int x[], int target, int low, int high)
            {
               if (low >= high) return -1; 
               int mid = (low + high)/2;
               if (x[mid] > target)
                  return BinarySearch(x, target, low, mid-1); 
               else if (x[mid] < target)
                  return BinarySearch(x, target, mid+1, high); ;
               return mid;
            }
            public int firstNnumber(int n)
            {
               if (n < 1) return 0;
               return firstNnumber(n-1) + n;
            }
            public int firstNnumber2(int n)
            {
               if (n==1) return 1;
               if (n==2) return 3;
               boolean even = (n%2 == 0);
               n /= 2;
               if (even)
               {
                   return 2*firstNnumber2(n) + n*n;
               }
               else
                   return 2*firstNnumber2(n) + (n + 1)*(1+n);
            }
            public int gaussian(int n)
            {
               return  n*(n+1)/2;
            }

            static public void main(String [] args)
            {
               Recursive r = new Recursive();
               System.out.println("By Gussain, Sum of first 100000 integers=" + r.gaussian(10000));
               System.out.println("By recurssion 2,    Sum of first 100000 integers=" + r.firstNnumber2(6)); 
            }


            }       

这是打印出来的,我不知道我的代码有什么问题。

通过Gussain,前100000个整数的总和= 50005000 通过递归2,前100000个整数的总和= 21

1 个答案:

答案 0 :(得分:1)

您使用错误的参数调用,请尝试使用

static public void main(String [] args){
  Recursive r = new Recursive();
  System.out.println("By Gussain, Sum of first 100000 integers=" + r.gaussian(10000));
  System.out.println("By recurssion 2,    Sum of first 100000 integers=" + r.firstNnumber2(10000)); 
}