#include #include #include #include #include #include #include #include #include #include #include #include #include #include typedef long long ll; using namespace std; #define debug(x) cerr << #x << " = " << x << endl; #define mod 1000000007 //1e9+7(prime number) #define INF 1000000000 //1e9 #define LLINF 2000000000000000000LL //2e18 #define SIZE 100010 struct LazySeg_sum{ struct Data{ ll val; ll add; ll sum; bool valset; ll calc_sum(int l, int r){ if(valset){ return (val + add) * (r - l + 1); }else{ return sum + add * (r - l + 1); } } Data():val(0),add(0),sum(0),valset(false){} }; vector data; int seg_size; LazySeg_sum(int n){ for(seg_size=1; seg_size < n; seg_size*=2); data.assign(seg_size*2, Data()); } ll set(int a, int b, ll x, int l=0, int r=-1,int k = 0){ if(r == -1) r = seg_size-1; if(a <= l && r <= b){ data[k].val = x; data[k].add = 0; data[k].valset = true; return data[k].calc_sum(l,r); } if(r < a || b < l) return 0; data[k*2+1].add += data[k].add; data[k*2+2].add += data[k].add; if(data[k].valset){ data[k*2+1].val += data[k].val; data[k*2+2].val += data[k].val; data[k*2+1].valset = true; data[k*2+2].valset = true; data[k].valset = false; } data[k].sum = set(a,b,x,l,(l+r)/2,k*2+1) + set(a,b,x,(l+r)/2+1,r,k*2+2); return data[k].calc_sum(l,r); } ll add(int a, int b, ll x, int l=0, int r=-1, int k = 0){ if(r == -1) r = seg_size-1; if(a <= l && r <= b){ data[k].add += x; return data[k].calc_sum(l,r); } if(r < a || b < l) return 0; if(data[k].valset){ data[k*2+1].val += data[k].val; data[k*2+2].val += data[k].val; data[k*2+1].valset = true; data[k*2+2].valset = true; data[k].valset = false; } data[k].sum = add(a,b,x,l,(l+r)/2,k*2+1) + add(a,b,x,(l+r)/2+1,r,k*2+2); return data[k].calc_sum(l,r); } ll query(int a, int b, int l=0, int r=-1, int k = 0){ if(r == -1) r = seg_size-1; if(a <= l && r <= b) return data[k].calc_sum(l,r); if(r < a || b < l) return 0; return query(a,b,l,(l+r)/2,k*2+1) + query(a,b,(l+r)/2+1,r,k*2+2) + data[k].add * (min(b,r) - max(a,l) + 1); } }; int main(){ int n,q; int base = INF; ll A = 0, B = 0; scanf("%d%d",&n,&q); LazySeg_sum seg(n); for(int i=0;i b ) A += a; if( b < a ) B += b; } } ll val = seg.query(0,INF); A += val%base; B += val/base; printf("%lld %lld\n",A,B); return 0; }