随笔 - 113  文章 - 0  评论 - 218  阅读 - 73万

求和比较高效的做法

写一个函数返回1+2+3+…+n的值(假定结果不会超过长整型变量的范围)

一般做法是:

int  sum(int n)

{

  long sum=0;

 for(int i=0;i<n;i++)

  {

   sum+=i;

  }

 return sum;
}

上面这种做法简单,方便可是效率怎么样,应该不是最好。

在数学上,我们有一个求和公式。n*(n+1)/2

于是有

int sum(int n)

{

  return n*(n+1)/2;
}

显然,这样效率显然比上面要好得很多。

所以有时候算法高效只需要一个转变。而数学公式正是求解的导向。

posted on   陈国利  阅读(322)  评论(3编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」
< 2010年11月 >
31 1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 1 2 3 4
5 6 7 8 9 10 11

点击右上角即可分享
微信分享提示