結果
問題 | No.1251 絶対に間違ってはいけない最小化問題 |
ユーザー | zumin |
提出日時 | 2021-03-25 00:00:25 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 622 ms / 2,000 ms |
コード長 | 991 bytes |
コンパイル時間 | 758 ms |
コンパイル使用メモリ | 83,868 KB |
実行使用メモリ | 87,692 KB |
最終ジャッジ日時 | 2024-11-26 23:42:10 |
合計ジャッジ時間 | 28,418 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 42 |
コンパイルメッセージ
In file included from /home/linuxbrew/.linuxbrew/Cellar/gcc@12/12.3.0/include/c++/12/iostream:39, from main.cpp:1: In member function 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long long int) [with _CharT = char; _Traits = std::char_traits<char>]', inlined from 'int main()' at main.cpp:43:11: /home/linuxbrew/.linuxbrew/Cellar/gcc@12/12.3.0/include/c++/12/ostream:202:25: warning: 'minx' may be used uninitialized [-Wmaybe-uninitialized] 202 | { return _M_insert(__n); } | ~~~~~~~~~^~~~~ main.cpp: In function 'int main()': main.cpp:34:8: note: 'minx' was declared here 34 | ll minx; | ^~~~
ソースコード
#include <iostream> #include <vector> #include <map> #include <atcoder/lazysegtree> using namespace std; using namespace atcoder; using ll=long long; ll op(ll a,ll b) {return a+b;} ll e() {return 0LL;} ll mapping(ll F,ll x) {return F+x;} ll composition(ll F,ll G) {return F+G;} ll id(){ return 0LL;} int main(){ ll n,dx=1000001,ans=0; cin>>n; vector<ll> a(n),b(n); lazy_segtree<ll,op,e,ll,mapping,composition,id> s(2000002); for(int i=0;i<n;i++) {cin>>a[i];a[i]+=dx;} for(int i=0;i<n;i++) cin>>b[i]; for(int i=0;i<n;i++){ ll ai=a[i],bi=b[i]; s.apply(0,bi*ai); s.apply(1,ai+1,-bi); s.apply(ai+1,2000002,bi); } vector<ll> csum={s.get(0)}; ll fmin=2001001001001001001; ll minx; for(ll i=0;i<2000001;i++){ csum.push_back(csum[i]+s.get(i+1)); ll f=csum[i+1]; if(f<fmin){ fmin=f; minx=i+1-dx; } } cout<<minx<<" "<<fmin<<endl; return 0; }