题解 | #求1+2+3+...+n#
求1+2+3+...+n
http://www.nowcoder.com/practice/7a0da8fc483247ff8800059e12d7caf1
jz47:求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<=n;i++){ s+=i; } return s; } }
版本2:
public class Solution { public int Sum_Solution(int n) { //公式 return n*(n+1)/2; } }
版本3:
public class Solution { public int Sum_Solution(int n) { return (int)(n*n+n)/2; } }
版本4:优
public class Solution { public int Sum_Solution(int n) { //Math.pow(底数,几次方) //>>带符号右移(相当于除以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** return (n==1) ? 1 : (n+Sum_Solution(n-1)); } }
版本7:优
public class Solution { public int Sum_Solution(int n) { //递归 **用&&代替if**(&&直到前面语句执行错误时,才停止执行下一个语句) boolean x = (n > 0) && ((n += Sum_Solution(n-1))>0); return n; } }