dp *1900

Please click on ads to support us..

C++ Code:

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

#define rep(i, a, n) for(int i=(a); i<(n); ++i)
#define per(i, a, n) for(int i=(a); i>(n); --i)
#define pb emplace_back
#define mp make_pair
#define clr(a, b) memset(a, b, sizeof(a))
#define all(x) (x).begin(),(x).end()
#define lowbit(x) (x & -x)
#define fi first
#define se second
#define lson o<<1
#define rson o<<1|1
#define gmid l[o]+r[o]>>1

using ll = long long;
using pii = pair<int,int>;
using pll = pair<ll, ll>;
using vi = vector<int>;

constexpr int mod = 998244353;
constexpr int inf = 0x3f3f3f3f;
constexpr int N = 3e4 + 10;

int n, d, cnt[N], suf[N];
unordered_map<int, int> dp[N];

void _main(){
  cin >> n >> d;
  int x, y, m = 0;
  rep(i, 0, n){
    cin >> x;
    m = max(m, x);
    ++cnt[x];
  }
  suf[m] = cnt[m];
  per(i, m-1, 0){
    suf[i] = suf[i+1] + cnt[i];
  }
  dp[d][d] = cnt[d];
  int ans = cnt[d];
  rep(i, d, m + 1){
    for(auto &p : dp[i]){
      x = p.fi;
      ans = max(ans, p.se);
      rep(j, -1, 2){
        y = x + j;
        if(y <= 0)  continue;
        if(i + y > m) continue;
        if(y == 1){
          ans = max(ans, p.se + suf[i + 1]);
          continue;
        }
        dp[i + y][y] = max(dp[i+y][y], p.se + cnt[i+y]);
      }
    }
  }
  cout << ans << '\n';
}

int main(){
  ios::sync_with_stdio(0);
  cin.tie(0); cout.tie(0);
  _main();
  return 0;
}


Comments

Submit
0 Comments
More Questions

1182A - Filling Shapes
82A - Double Cola
45A - Codecraft III
1242A - Tile Painting
1663E - Are You Safe
1663D - Is it rated - 3
1311A - Add Odd or Subtract Even
977F - Consecutive Subsequence
939A - Love Triangle
755A - PolandBall and Hypothesis
760B - Frodo and pillows
1006A - Adjacent Replacements
1195C - Basketball Exercise
1206A - Choose Two Numbers
1438B - Valerii Against Everyone
822A - I'm bored with life
9A - Die Roll
1430B - Barrels
279B - Books
1374B - Multiply by 2 divide by 6
1093B - Letters Rearranging
1213C - Book Reading
1468C - Berpizza
1546B - AquaMoon and Stolen String
1353C - Board Moves
902A - Visiting a Friend
299B - Ksusha the Squirrel
1647D - Madoka and the Best School in Russia
1208A - XORinacci
1539B - Love Song