Home > Software engineering >  Recursive SUM function javascript
Recursive SUM function javascript

Time:12-16

I have been given the function below in pseudocode and I am trying to translate it to JS, but I keep getting an infinity loop.


Update

Thanks zord, mid fixed the recursion issue. Now I get the wrong sum, any suggestions?

What am I doing wrong?

function SUM(arr, left, right){
  
    if(left > right){ 
        return 0 
    }
    else if(left == right){
      return arr[left]
    }

    mid = Math.floor((left   right) / 2);

    lsum = SUM(arr,left,mid);
    rsum = SUM(arr,mid 1,right); 

    return lsum   rsum

}

arr = [1,2,3,4,5]
left = 0;
right = arr.length - 1;


console.log(SUM(arr, left, right));

Thanks!

CodePudding user response:

mid should be halfway between left and right:

mid = Math.floor((left   right) / 2);

Also, you need to make your variables block scoped as VLAZ mentioned. Otherwise they will be global, and overwritten by different runs of the function.

const mid = Math.floor((left   right) / 2);

const lsum = SUM(arr, left, mid);
const rsum = SUM(arr, mid   1, right); 
  • Related