剑指offer试题1.求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)。

  • 短路求值:
    作为"&&“和”||"操作符的操作数表达式,这些表达式在进行求值时,只要最终的结果已经可以确定是真或假,求值过程便告终止,这称之为短路求值(short-circuit evaluation)。
    假如expr1和expr2都是表达式,并且expr1的值为0,在下面这个逻辑表达式的求值过程中:
    1.expr1 && expr2
    expr2将不会执行,因为在&&中有一个为0那么剩下的另外一个就不用执行,类似于物理中的电路短路。
    2.expr1 || expr2
    expr2将不会进行求值,因为整个逻辑表达式的值已经确定为1。
    来自百度百科。

思路

  • 可以利用左边的表达式来作为递归结束的判断条件。因此递归的表达式就在右边了。而想到递归的解法,必然是sum=Sum(n)=Sum(n-1)+n
    使用&&,表示两边都为真,才为真,左边为假,右边就没用了。
    因此在不断递归时,直到左边为假时,才不执行右边。因此在第一次进行右边的判断时,就进入递归的调用。
    想到结束条件在左边,只能是n=0时结束,即从n递减到0结束,所以递归的调用理所当然放在了右边。由于左边需要不断的进行条件判断,因为需要一个每次递归后都递减的变量,而n是递减的,因此用n来作为左边的变量,int
    sum = n; 而短路求值左边可以写为(n>0)或(n!=0),右边写为sum
    +=sum(n-1),再加一个判断(实际上需要保证右边的条件一直为真),因此java版的解法就出来了

  • 利用等差数列求和公式,其中pow(a,b)表示a的b次方
    知识点:Math.pow(n, 2)

  • 右移左移(尖头指向哪就是向哪边移动)
    1.左移:相当于乘以2^n ,丢弃最高位,0补最低位
    左移运算是将一个二进制位的操作数按指定移动的位数向左移位,移出位被丢弃,右边的空位一律补0。
    2.右移:除以2^n
    右移运算是将一个二进制位的操作数按指定移动的位数向右移动,移出位被丢弃,左边移出的空位或者一律补0,或者补符号位,这由不同的机器而定。在使用补码作为机器数的机器中,正数的符号位为0,负数的符号位为1。(均由机器来定:这个不正确)(MSDN原文明确说明,右移对于无符号类型强制补0,对于有符号类型续补符号位)
    一般情况下 你要乘或者是除以数字是2的次方的话都可以用的,执行速度快

m>>1(右移1位相当于除以2)符号位向右移动后,正数的话补0,负数补1,

  int i=5;
    i=i>>2;

5>>2=1
0000 0000 0000 0000 0000 0000 0000 0101
0000 0000 0000 0000 0000 0000 0000 0001
其结果与 5/(2*2) 完全相同。

m<<1(左移1位相当于乘以2)

  int i=1;
    i=i<<2;

1的2进制是
00000001
(这里前面0的个数和int的位数有关,32位机器,gcc里有31个0),左移2位之后变成:
00000100,
就是10进制的4,所以说左移1位相对于乘以2的n次方
其结果与 1*2^2)完全相同。

public class Solution {
    public int Sum_Solution(int n) {
        int sum = n;
        boolean an = (n>0)&&((sum += Sum_Solution(n-1)) > 0);
        return sum;

//方法二求数组个数
       int m = (int)Math.pow(n, 2)+n;		//等差数列求和公式:则原题sum=(n+n*n)/2  n*n即n的平方
       return m>>1;	//右移一位相当于除以2.
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

微莱羽墨

感谢支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值