劍指offer——求1+2+...+n

方法1、經過在類的構造函數中執行加的過程。ios

#include <iostream>
using namespace std;
class Base
{
public:
    Base(){n++;sum+=n;}
    static int GetSum(){return sum;}
private:
    static unsigned int n;
    static unsigned int sum;
};
unsigned int Base::n=0;
unsigned int Base::sum=0;
int main()
{
    Base *b=new Base[100];
    cout<<Base::GetSum()<<endl;
    return 1;
}

方法2、利用題目的特殊性。其實仍是能夠遞歸的。&&有短路的做用,在n減爲0的時候中止遞歸。
函數

#include <stdio.h>

int dfs(int n)
{
    int s=0;
    n&&(s=n+dfs(n-1));
    return s;
}

int main()
{
    printf("%d\n",dfs(100));
    return 0;
}
相關文章
相關標籤/搜索