#include #if __has_include() #include using namespace atcoder; #endif using namespace std; using ll = long long; int main() { ll n,x; cin >> n >> x; vector> a(n); for(int i=0;i> a[i].first >> a[i].second; } vector ans(x+1); for(int i=0;i b(x+1); for(int j=max(a[i].first-a[i].second,0LL);j<=min(a[i].first+a[i].second,x-1)+1;j++){ b[j]+=max(a[i].second-abs(a[i].first-j),0LL); ans[j]=max(ans[j],b[j]); } } for(int i=1;i<=x;i++){ cout << ans[i] << " "; } cout << endl; } // vector a(); // for(int i=0;i> 変数名(n, vector(m, 0)); // for(int i=0;i()); // do{ // }while(next_permutation(a.begin(),a.end())); // cout << fixed << setprecision(15) << ans << endl; // deque<型> 変数名; // d.push_back(value) d.push_front(value) // d.front() d.back()d.at(i) // d.pop_back() d.pop_front() // d.size() d.empty() // for(ll bit=0;bit<(1<