题解 | #求1+2+3+...+n#

求1+2+3+...+n

http://www.nowcoder.com/practice/7a0da8fc483247ff8800059e12d7caf1

import java.util.*;
应该说看到这种只能加减,不能乘除,也不能循环,不能使用判断等等这些条件就知道了
肯定要用位运算。
左移一位相当于乘以2,右移一位相当于除以2,这是基本的常识。记不起来可以举一个0010的例子移动一下1
然后把(首项+末项)*项数/2进一步化简,即为(n+n²)/2.平方就用Math.pow就可以了
右移是>>,左移是<<。注意是两个符号连在一起

public class Solution {
    public int Sum_Solution(int n) {
        int sum = 0;//初始化结果
        sum = (int)(n + Math.pow(n,2)) >> 1;//通过右移一位来代替除以2,注意要强转一下
        return sum;
    }
}
全部评论

相关推荐

牛客37185681...:马德,我感觉这是我面过最恶心的公司,一面是两个女hr,说什么实习前几个月属于试用期,试用期过了才能转成正式实习生,我***笑了,问待遇就是不说,问能不能接受全栈,沙币公司
如果可以选,你最想去哪家...
点赞 评论 收藏
分享
评论
7
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务