剑指OfferJZ47:求1+2+3+...+n-java版 
 
 
 
求1+2+3+…+n;要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C) 
- 求1+2+3+...+n;要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)
 
版本1:
public class Solution {
    public int Sum_Solution(int n) {
        //for循环
        int s=0;
        for(int i=0;i>带符号右移(相当于除以2)
        return (int)(Math.pow(n,2)+n)>>1;
    }
}
版本5:
public class Solution {
    public int Sum_Solution(int n) {
        //递归
        if (n == 1) return n;
        return n + Sum_Solution(n-1);
    }
}
版本6:
public class Solution {
    public int Sum_Solution(int n) {
        //递归 用&&代替if(&&直到前面语句执行错误时,才停止执行下一个语句)
        boolean x = (n > 0) && ((n += Sum_Solution(n-1))>0);
        return n;
    }
}
版本7:
public class Solution {
    public int Sum_Solution(int n) {
        //递归 用?:条件运算符代替if
        return (n==1) ? 1 : (n+Sum_Solution(n-1));
    }
}

 
                 
    