【题目链接】

             点击打开链接

【算法】

          动态规划

          f[i]表示上一次打了第i只鼹鼠,所能打死的最多的鼹鼠数量

【代码】

          

#include<bits/stdc++.h>
using namespace std;
#define MAXM 10010

int i,j,n,m,ans;
int t[MAXM],x[MAXM],y[MAXM],f[MAXM];

int main() {
        
        scanf("%d%d",&n,&m);
        for (i = 1; i <= m; i++) scanf("%d%d%d",&t[i],&x[i],&y[i]);
        for (i = 1; i <= m; i++) {
                f[i] = 1;
                for (j = i - 1; j >= 1; j--) {
                        if (abs(x[i] - x[j]) + abs(y[i] - y[j]) <= t[i] - t[j])
                                f[i] = max(f[i],f[j]+1);
                }        
        }
        for (i = 1; i <= m; i++) ans = max(ans,f[i]); 
        printf("%d\n",ans);
        
        return 0;
    
}

 

相关文章:

  • 2022-01-31
  • 2022-01-26
  • 2022-02-04
  • 2021-11-09
  • 2021-06-09
  • 2022-12-23
  • 2022-12-23
  • 2021-07-11
猜你喜欢
  • 2022-12-23
  • 2021-07-21
  • 2021-12-30
  • 2022-03-03
  • 2021-10-12
  • 2022-03-06
  • 2021-06-25
相关资源
相似解决方案