結果
| 問題 | No.3417 Tired Santa |
| コンテスト | |
| ユーザー |
Nachia
|
| 提出日時 | 2025-12-24 11:40:00 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 13 ms / 2,000 ms |
| コード長 | 712 bytes |
| 記録 | |
| コンパイル時間 | 2,009 ms |
| コンパイル使用メモリ | 201,356 KB |
| 実行使用メモリ | 11,008 KB |
| 最終ジャッジ日時 | 2025-12-24 11:40:03 |
| 合計ジャッジ時間 | 3,590 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 25 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
#define REP(i,n) for(ll i=0; i<ll(n); i++)
int main(){
ll N, S; cin >> N >> S;
vector<ll> X(N), W(N), sum(N+1);
vector dp(N, vector(N,1ll<<60));
REP(I,N) cin >> X[I];
REP(i,N) cin >> W[i];
REP(i,N) sum[i+1] = sum[i] + W[i];
REP(i,N) dp[i][i] = abs(S - X[i]) * sum[N];
REP(r,N) for(ll l=r; l>=0; l--){
ll w = sum[N] - sum[r+1] + sum[l];
if(0 < l) dp[l-1][r] = min({dp[l-1][r], dp[l][r] + w * (X[l] - X[l-1]), dp[r][l] + w * (X[r] - X[l-1])});
if(r+1 < N) dp[r+1][l] = min({dp[r+1][l], dp[l][r] + w * (X[r+1] - X[l]), dp[r][l] + w * (X[r+1] - X[r])});
}
cout << min(dp[0][N-1], dp[N-1][0]) << "\n";
return 0;
}
Nachia