Submission #993329
Source Code Expand
#include <bits/stdc++.h> #define FOR(i,a,b) for( ll i = (a); i < (ll)(b); i++ ) #define REP(i,n) FOR(i,0,n) #define YYS(x,arr) for(auto& x:arr) #define ALL(x) (x).begin(),(x).end() #define SORT(x) sort( (x).begin(),(x).end() ) #define REVERSE(x) reverse( (x).begin(),(x).end() ) #define UNIQUE(x) (x).erase( unique( ALL( (x) ) ) , (x).end() ) #define PW(x) (1LL<<(x)) #define SZ(x) ((ll)(x).size()) #define SHOW(x) cout << #x << " = " << x << endl #define pb emplace_back #define fi first #define se second using namespace std; typedef long double ld; typedef long long int ll; typedef pair<int,int> pi; typedef pair<ll,ll> pl; typedef vector<int> vi; typedef vector<ll> vl; typedef vector<bool> vb; typedef vector<ld> vd; typedef vector<pi> vpi; typedef vector<pl> vpl; typedef vector<vpl> gr; typedef vector<vl> ml; typedef vector<vd> md; typedef vector<vi> mi; const ll INF = (ll)1e9 + 10; const ll INFLL = (ll)1e18 + 10; const ld EPS = 1e-8; const ll MOD = 1e9+7; template<class T> T &chmin( T &a , const T &b ){ return a = min(a,b); } template<class T> T &chmax( T &a , const T &b ){ return a = max(a,b); } template<class T> inline T sq( T a ){ return a * a; } ll in(){ ll x; scanf( "%lld" , &x ); return x; } // head struct ConvexHullTrick{ vi st; vl a, b; int s, t, it; void init( int n ){ st = vi( n ); a.clear(); b.clear(); s = t = 0; } bool check( int i , int j , int k ){ // return ( a[i] - a[j] ) * ( b[k] - b[i] ) > ( a[i] - a[k] ) * ( b[j] - b[i] ); return ( a[k] - a[i] ) * ( b[i] - b[j] ) > ( b[i] - b[k] ) * ( a[j] - a[i] ); } void add( ll ca , ll cb ){ a.pb( ca ); b.pb( cb ); while( s <= t-2 && check( st[t-2] , st[t-1] , SZ(a)-1 ) ) t--; st[t++] = SZ(a)-1; } ll f( int i , ll x ){ return a[i] * x + b[i]; } ll query( ll x ){ while( s+1 < t && f(st[s],x) <= f(st[s+1],x) ) s++; return f(st[s],x); } }; ConvexHullTrick cht; ll dp[4000010]; ll n, a; ll ans; ll f( ll x , ll y ){ return dp[x] * ( y - x - a ); } bool check( ll x ){ if( x >= n ){ return true; } REP( i , 4000010 ){ if( dp[i] * ( x - i - a ) >= n ){ return true; } } return false; } int main(){ n = in(); a = in(); cht.init( 4000010 ); FOR( i , 1 , 4000010 ){ dp[i] = i; if( cht.s < cht.t ){ chmax( dp[i] , cht.query( i ) ); } cht.add( dp[i] , dp[i] * ( - i - a ) ); if( dp[i] >= n ){ cout << i << endl; return 0; } } ll lb = 0, ub = n+1; while( ub - lb > 1 ){ ll md = ( lb + ub ) / 2; if( check( md ) ){ ub = md; } else { lb = md; } } cout << ub << endl; // assert( false ); return 0; }
Submission Info
Submission Time | |
---|---|
Task | E - Cookies |
User | joisino |
Language | C++14 (GCC 5.4.1) |
Score | 500 |
Code Size | 2819 Byte |
Status | WA |
Exec Time | 364 ms |
Memory | 109892 KB |
Compile Error
./Main.cpp: In function ‘ll in()’: ./Main.cpp:43:36: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result] ll in(){ ll x; scanf( "%lld" , &x ); return x; } ^
Judge Result
Set Name | sample | dataset1 | dataset2 | ||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 500 / 500 | 0 / 500 | ||||||||
Status |
|
|
|
Set Name | Test Cases |
---|---|
sample | sample-01.txt, sample-02.txt, sample-03.txt |
dataset1 | sample-01.txt, 01-01.txt, 01-02.txt, 01-03.txt, 01-04.txt, 01-05.txt, 01-06.txt, 01-07.txt, 01-08.txt, 01-09.txt, 01-10.txt, 01-11.txt, 01-12.txt, 01-13.txt, 01-14.txt, 01-15.txt, 01-16.txt, 01-17.txt, 01-18.txt, 01-19.txt, 01-20.txt, 01-21.txt, 01-22.txt, 01-23.txt, 01-24.txt, 01-25.txt, 01-26.txt |
dataset2 | sample-01.txt, sample-02.txt, sample-03.txt, 01-01.txt, 01-02.txt, 01-03.txt, 01-04.txt, 01-05.txt, 01-06.txt, 01-07.txt, 01-08.txt, 01-09.txt, 01-10.txt, 01-11.txt, 01-12.txt, 01-13.txt, 01-14.txt, 01-15.txt, 01-16.txt, 01-17.txt, 01-18.txt, 01-19.txt, 01-20.txt, 01-21.txt, 01-22.txt, 01-23.txt, 01-24.txt, 01-25.txt, 01-26.txt, 02-01.txt, 02-02.txt, 02-03.txt, 02-04.txt, 02-05.txt, 02-06.txt, 02-07.txt, 02-08.txt, 02-09.txt, 02-10.txt, 02-11.txt, 02-12.txt, 02-13.txt, 02-14.txt, 02-15.txt, 02-16.txt, 02-17.txt, 02-18.txt, 02-19.txt, 02-20.txt, 02-21.txt, 02-22.txt, 02-23.txt, 02-24.txt, 02-25.txt, 02-26.txt, 02-27.txt, 02-28.txt, 02-29.txt, 02-30.txt, 02-31.txt, 02-32.txt, 02-33.txt, 02-34.txt, 02-35.txt, 02-36.txt, 02-37.txt, 02-38.txt, 02-39.txt, 02-40.txt |
Case Name | Status | Exec Time | Memory |
---|---|---|---|
01-01.txt | AC | 19 ms | 15872 KB |
01-02.txt | AC | 19 ms | 15872 KB |
01-03.txt | AC | 19 ms | 15872 KB |
01-04.txt | AC | 19 ms | 15872 KB |
01-05.txt | AC | 19 ms | 15872 KB |
01-06.txt | AC | 21 ms | 15872 KB |
01-07.txt | AC | 21 ms | 15872 KB |
01-08.txt | AC | 21 ms | 15872 KB |
01-09.txt | AC | 21 ms | 15872 KB |
01-10.txt | AC | 21 ms | 15872 KB |
01-11.txt | AC | 21 ms | 15872 KB |
01-12.txt | AC | 78 ms | 39508 KB |
01-13.txt | AC | 76 ms | 39508 KB |
01-14.txt | AC | 21 ms | 15872 KB |
01-15.txt | AC | 21 ms | 15872 KB |
01-16.txt | AC | 21 ms | 15872 KB |
01-17.txt | AC | 21 ms | 15872 KB |
01-18.txt | AC | 21 ms | 15872 KB |
01-19.txt | AC | 21 ms | 15872 KB |
01-20.txt | AC | 21 ms | 15872 KB |
01-21.txt | AC | 20 ms | 15872 KB |
01-22.txt | AC | 20 ms | 15872 KB |
01-23.txt | AC | 21 ms | 15872 KB |
01-24.txt | AC | 21 ms | 15872 KB |
01-25.txt | AC | 21 ms | 15872 KB |
01-26.txt | AC | 21 ms | 15872 KB |
02-01.txt | AC | 19 ms | 15872 KB |
02-02.txt | WA | 20 ms | 15872 KB |
02-03.txt | WA | 18 ms | 15872 KB |
02-04.txt | WA | 20 ms | 15872 KB |
02-05.txt | WA | 19 ms | 15872 KB |
02-06.txt | AC | 19 ms | 15872 KB |
02-07.txt | WA | 21 ms | 15872 KB |
02-08.txt | WA | 20 ms | 15872 KB |
02-09.txt | WA | 21 ms | 15872 KB |
02-10.txt | WA | 21 ms | 15872 KB |
02-11.txt | WA | 20 ms | 15872 KB |
02-12.txt | WA | 21 ms | 15872 KB |
02-13.txt | AC | 20 ms | 15872 KB |
02-14.txt | AC | 19 ms | 15872 KB |
02-15.txt | WA | 19 ms | 15872 KB |
02-16.txt | WA | 21 ms | 15872 KB |
02-17.txt | AC | 21 ms | 15872 KB |
02-18.txt | WA | 19 ms | 16000 KB |
02-19.txt | AC | 21 ms | 16000 KB |
02-20.txt | AC | 20 ms | 16256 KB |
02-21.txt | WA | 26 ms | 18164 KB |
02-22.txt | AC | 247 ms | 109124 KB |
02-23.txt | AC | 364 ms | 109892 KB |
02-24.txt | AC | 364 ms | 109892 KB |
02-25.txt | AC | 21 ms | 15872 KB |
02-26.txt | AC | 21 ms | 15872 KB |
02-27.txt | WA | 19 ms | 15872 KB |
02-28.txt | WA | 18 ms | 15872 KB |
02-29.txt | WA | 20 ms | 15872 KB |
02-30.txt | WA | 19 ms | 15872 KB |
02-31.txt | WA | 19 ms | 15872 KB |
02-32.txt | WA | 19 ms | 15872 KB |
02-33.txt | AC | 21 ms | 15872 KB |
02-34.txt | WA | 20 ms | 15872 KB |
02-35.txt | WA | 20 ms | 15872 KB |
02-36.txt | WA | 21 ms | 15872 KB |
02-37.txt | WA | 21 ms | 16000 KB |
02-38.txt | AC | 21 ms | 16512 KB |
02-39.txt | AC | 113 ms | 56396 KB |
02-40.txt | AC | 270 ms | 109892 KB |
sample-01.txt | AC | 19 ms | 15872 KB |
sample-02.txt | AC | 364 ms | 109892 KB |
sample-03.txt | AC | 20 ms | 15872 KB |