剑指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));
}
}