結果
問題 | No.2408 Lakes and Fish |
ユーザー | vjudge1 |
提出日時 | 2024-05-01 23:36:55 |
言語 | C++17(clang) (17.0.6 + boost 1.87.0) |
結果 |
RE
|
実行時間 | - |
コード長 | 2,553 bytes |
コンパイル時間 | 2,679 ms |
コンパイル使用メモリ | 163,948 KB |
実行使用メモリ | 8,448 KB |
最終ジャッジ日時 | 2024-11-22 07:47:16 |
合計ジャッジ時間 | 6,675 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
5,248 KB |
testcase_01 | AC | 2 ms
5,248 KB |
testcase_02 | AC | 2 ms
5,248 KB |
testcase_03 | AC | 2 ms
5,248 KB |
testcase_04 | RE | - |
testcase_05 | RE | - |
testcase_06 | AC | 77 ms
8,448 KB |
testcase_07 | RE | - |
testcase_08 | RE | - |
testcase_09 | RE | - |
testcase_10 | RE | - |
testcase_11 | RE | - |
testcase_12 | RE | - |
testcase_13 | RE | - |
testcase_14 | RE | - |
testcase_15 | RE | - |
testcase_16 | RE | - |
testcase_17 | RE | - |
testcase_18 | RE | - |
testcase_19 | RE | - |
testcase_20 | RE | - |
testcase_21 | RE | - |
ソースコード
#include <bits/stdc++.h> using namespace std; /* clang-format off */ /* TYPES */ #define ll long long //~ #define pii pair<int, int> //~ #define pll pair<long long, long long> //~ #define vi vector<int> //~ #define vll vector<long long> //~ #define mii map<int, int> //~ #define si set<int> //~ #define sc set<char> /* FUNCTIONS */ //~ #define f(i,s,e) for(long long int i=s;i<e;i++) //~ #define cf(i,s,e) for(long long int i=s;i<=e;i++) //~ #define rf(i,e,s) for(long long int i=e-1;i>=s;i--) //~ #define pb push_back //~ #define eb emplace_back /* PRINTS */ //~ template <class T> //~ void print_v(vector<T> &v) { cout << "{"; for (auto x : v) cout << x << ","; cout << "\b}"; } //~ #define MOD 1000000007 //~ #define PI 3.1415926535897932384626433832795 //~ #define read(type) readInt<type>() //~ ll min(ll a,int b) { if (a<b) return a; return b; } //~ ll min(int a,ll b) { if (a<b) return a; return b; } //~ ll max(ll a,int b) { if (a>b) return a; return b; } //~ ll max(int a,ll b) { if (a>b) return a; return b; } //~ ll gcd(ll a,ll b) { if (b==0) return a; return gcd(b, a%b); } //~ ll lcm(ll a,ll b) { return a/gcd(a,b)*b; } //~ string to_upper(string a) { for (int i=0;i<(int)a.size();++i) if (a[i]>='a' && a[i]<='z') a[i]-='a'-'A'; return a; } //~ string to_lower(string a) { for (int i=0;i<(int)a.size();++i) if (a[i]>='A' && a[i]<='Z') a[i]+='a'-'A'; return a; } //~ bool prime(ll a) { if (a==1) return 0; for (int i=2;i<=round(sqrt(a));++i) if (a%i==0) return 0; return 1; } //~ void yes() { cout<<"YES\n"; } //~ void no() { cout<<"NO\n"; } const int MAXN = 1e5 + 5; int treesPos[MAXN]; int main(){ ios_base::sync_with_stdio(false); cin.tie(NULL); int N, M; auto distance = [] (int i, int j) { return std::abs(i-j); }; cin >> N >> M; set<int> trees; ll sum = 0; for(int i = 0; i < N; i++) { int a; cin >> a; trees.insert(a); treesPos[a] = 1; } for(int i = 0; i < M; i++) { ll f, b, w; cin >> f >> b >>w; if(treesPos[f] == 1) { sum += w; continue; } auto dis = upper_bound(trees.begin(), trees.end(), f); if(dis == trees.end()) { dis--; } auto also = dis; if(also != trees.begin()) { also--; } int diff = min(abs(*dis - f), abs(*also - f)); // int diff = abs(*dis - f); // cout << f << " " << diff << "\n"; sum += max(b, w-diff); } cout << sum ; return 0; }