#include<iostream>
#include<vector>
#include<set>
#include<map>
#include<numeric>
#include<string>
#include<stack>
#include<queue>
#include<string.h>
#include<array>
#include<climits>
#include<algorithm>
#include<cmath>
using namespace std;
#define ff first
#define int long long
#define ss second
const int mx = 1500000;
#define int long long
const long long inf = 1e18;
#define endl '\n'
struct ST{
int n;
vector<int> tree;
vector<int> lazy;
ST(int size){
n = size;
tree.resize(4 * n, -inf);
lazy.resize(4 * n);
}
void push(int node, int start, int end){
if(lazy[node] != 0){
tree[node] = max(tree[node], lazy[node] * (end - start + 1));
if(start != end){
lazy[2 * node] += lazy[node];
lazy[2 * node + 1] += lazy[node];
}
lazy[node] = 0LL;
}
}
void update(int node, int start, int end, int l, int r, int val){
push(node, start, end);
if(start > r || end < l) return;
if(start >= l && end <= r){
lazy[node] = max(lazy[node], val);
push(node, start, end);
return;
}
int mid = (start + end) / 2;
update(2 * node, start, mid, l, r, val);
update(2 * node + 1, mid + 1, end, l, r, val);
tree[node] = tree[2 * node] + tree[2 * node + 1];
}
int query(int node, int start, int end, int id){
push(node, start, end);
if(start == end){
return tree[node];
}
else{
int mid = (start + end) / 2;
if(mid >= id){
return query(2 * node, start, mid, id);
}
else{
return query(2 * node + 1, mid + 1, end, id);
}
}
}
};
signed main(){
int n, m;
cin >> n >> m;
ST st(n);
for(int i = 0; i < m; i++){
int L, R, X;
cin >> L >> R >> X;
L--, R--;
st.update(1, 0, n - 1, L, R, X - L);
}
vector<int> g(n);
for(int i = 0; i < n; i++){
cout << max(0LL, st.query(1, 0, n - 1, i) + i) << " ";
}
}