uva10943 How do you add?(DP)
#include <iostream> #include <cstring> #define mod 1000000 using namespace std; int dp[110][110]; int DP(int x,int y){ if(dp[x][y]!=-1) return dp[x][y]; if(y==1) return dp[x][y]=1; int ret=0; for(int i=0;i<=x;i++){ ret+=DP(i,y-1); ret%=mod; } return dp[x][y]=ret%mod; } int main(){ int n,k; while(cin>>n>>k){ if(n==0&&k==0) break; memset(dp,-1,sizeof dp); cout<<DP(n,k)<<endl; } return 0; }