//jiudge: 26921: 1687360739
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N = 1e5+10;
int dp[N];
struct xx {
int t, x, y;
}a[N];
int dis(xx a1, xx a2) {
return abs(a1.x-a2.x)+abs(a1.y-a2.y);
}
int main() {
memset(dp, -1, sizeof dp);
int r, n;
scanf("%d%d", &r, &n);
a[0].x = 1, a[0].y = 1; dp[0] = 0;
for(int i = 1; i <= n; ++i) scanf("%d%d%d", &a[i].t, &a[i].x, &a[i].y);
for(int i = 1; i <= n; ++i) {
for(int j = max(0, i-1-r*4); j < i; ++j) {
if(dp[j] != -1 && a[i].t - a[j].t >= dis(a[i], a[j]))
dp[i] = max(dp[i], dp[j]+1);
}
}
int ans = 0;
for(int i = 1; i <= n; ++i) ans = max(ans, dp[i]);
printf("%d\n", ans);
return 0;
}
1593C - Save More Mice | 1217. Minimum Cost to Move Chips to The Same Position |
347. Top K Frequent Elements | 1503. Last Moment Before All Ants Fall Out of a Plank |
430. Flatten a Multilevel Doubly Linked List | 1290. Convert Binary Number in a Linked List to Integer |
1525. Number of Good Ways to Split a String | 72. Edit Distance |
563. Binary Tree Tilt | 1306. Jump Game III |
236. Lowest Common Ancestor of a Binary Tree | 790. Domino and Tromino Tiling |
878. Nth Magical Number | 2099. Find Subsequence of Length K With the Largest Sum |
1608A - Find Array | 416. Partition Equal Subset Sum |
1446. Consecutive Characters | 1618A - Polycarp and Sums of Subsequences |
1618B - Missing Bigram | 938. Range Sum of BST |
147. Insertion Sort List | 310. Minimum Height Trees |
2110. Number of Smooth Descent Periods of a Stock | 2109. Adding Spaces to a String |
2108. Find First Palindromic String in the Array | 394. Decode String |
902. Numbers At Most N Given Digit Set | 221. Maximal Square |
1200. Minimum Absolute Difference | 1619B - Squares and Cubes |