TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

Choose Elements

問題

C – Choose Elements
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 62;
// const int INF = 1001001001;

ll N, K;
vector<ll> A;
vector<ll> B;

bool flg = false;

int main() {
  cin >> N >> K;

  A.resize(N);
  rep(i, N) { cin >> A[i]; }

  B.resize(N);
  rep(i, N) { cin >> B[i]; }

  vector<vector<bool>> dp(N, vector<bool>(2));
  dp[0][0] = true;
  dp[0][1] = true;

  rep(i, N - 1) {
    if(dp[i][0]) {
      if(abs(A[i] - A[i + 1]) <= K) {
        dp[i + 1][0] = true;
      }
      if(abs(A[i] - B[i + 1]) <= K) {
        dp[i + 1][1] = true;
      }
    }

    if(dp[i][1]) {
      if(abs(B[i] - A[i + 1]) <= K) {
        dp[i + 1][0] = true;
      }
      if(abs(B[i] - B[i + 1]) <= K) {
        dp[i + 1][1] = true;
      }
    }
  }

  if(dp[N - 1][0] || dp[N - 1][1]) {
    cout << "Yes" << endl;
  } else {
    cout << "No" << endl;
  }
  return 0;
}