方法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; }