#include "stream.h" #include #include #include #include long timeval_diff(struct timeval &tv1, struct timeval &tv2) { long ret = tv1.tv_usec - tv2.tv_usec; if(ret<0) ret += 1000000; return ret; } long change(int n, int max=50) { if(n<0) return 0; if(n==0) return 1; long ret = 0; if(n>=1 && max>=1) ret+=change(n-1, 1); if(n>=2 && max>=2) ret+=change(n-2, 2); if(n>=5 && max>=5) ret+=change(n-5, 5); if(n>=10 && max>=10) ret+=change(n-10, 10); if(n>=20 && max>=20) ret+=change(n-20, 20); if(n>=50 && max>=50) ret+=change(n-50, 50); return ret; } long changef(int n, int max=4) { if(n<0) return 0; long ret = 1; switch(max) { case 4: ret += changef(n-50, 4); case 3: ret += changef(n-20, 3); case 2: ret += changef(n-10, 2); case 1: ret += changef(n-5, 1); case 0: ret += changef(n-2, 0); } return ret; } long changedyn0(int n, int max=4) { if(n<0) return 0; if(max<0) return 1; static std::map cache[5]; std::map::iterator it = cache[max].find(n); if(it != cache[max].end()) return cache[max][n]; long ret = 1; switch(max) { case 4: ret += changedyn0(n-50, 4); case 3: ret += changedyn0(n-20, 3); case 2: ret += changedyn0(n-10, 2); case 1: ret += changedyn0(n-5, 1); case 0: ret += changedyn0(n-2, 0); } cache[max][n] = ret; return ret; } long changedyn(int n, int max=4) { if(n<0) return 0; if(max<0) return 1; static std::unordered_map cache[5]; std::unordered_map::iterator it = cache[max].find(n); if(it != cache[max].end()) return cache[max][n]; long ret = 1; switch(max) { case 4: ret += changedyn(n-50, 4); case 3: ret += changedyn(n-20, 3); case 2: ret += changedyn(n-10, 2); case 1: ret += changedyn(n-5, 1); case 0: ret += changedyn(n-2, 0); } cache[max][n] = ret; return ret; } template stream times(long n, long val, ST && s) { if(n==0) return s; return times(n-1, val, val<<=std::forward(s)); } stream change1 = 1l<<=change1; stream change2 = times(2, 0, change2) + change1; stream change5 = times(5, 0, change5) + change2; stream change10 = times(10, 0, change10) + change5; stream change20 = times(20, 0, change20) + change10; stream change50 = times(50, 0, change50) + change20; int main(int, char *argv[]) { // stream::iterator it = change50.begin(); // for(int i=0; i<20; ++i) // { // assert(change(i) == *it); // std::cout<::iterator it = change50.begin(); for(int i=0; i