Submission #1097424

#TimeUsernameProblemLanguageResultExecution timeMemory
1097424StefanSebezSemiexpress (JOI17_semiexpress)C++14
0 / 100
1 ms348 KiB
#include <bits/stdc++.h> using namespace std; #define fi first #define se second #define pb push_back #define ll long long #define ld long double int main(){ int n,m,K;scanf("%i%i%i",&n,&m,&K); K-=m; ll A,B,C;scanf("%lld%lld%lld",&A,&B,&C); ll T;scanf("%lld",&T); ll a[m+10];for(int i=1;i<=m;i++) scanf("%lld",&a[i]); ll ind[m+10]; set<pair<int,int>>st; for(int i=1;i<=m;i++){ ind[i]=a[i]; /*ll x=B*(a[i]-a[1]); //(j-ind[i])*A+(ind[i]-a[i])*C+(a[i]-a[1])*B<=T ll j=(T-(ind[i]-a[i])*C-(a[i]-a[1])*B)/A; j=min(j,a[i+1]); res+=j-ind[i]+1; if(j<a[i+1]) st.insert({j-a[i],i});*/ if((a[i]-a[1])*B>T) m=i-1; } if(a[m]==n) m--; //printf("%lld\n",m); ll res=m; for(int i=1;i<=m&&K>0;K--){ if(ind[i]==a[i]) {res--;K++;} if(T-(ind[i]-a[i])*C-(a[i]-a[1])*B<0){i++;continue;} ll j=(T-(ind[i]-a[i])*C-(a[i]-a[1])*B)/A+ind[i]; j=min(j,a[i+1]-1); //printf("%i: %lld %lld %lld %lld %lld\n",i,j,ind[i],(ind[i]-a[i]),(a[i]-a[1]),T-(ind[i]-a[i])*C-(a[i]-a[1])*B); res+=j-ind[i]+1; ind[i]=j+1; if(ind[i]==a[i+1]) i++; } res--; printf("%lld\n",res); return 0; }

Compilation message (stderr)

semiexpress.cpp: In function 'int main()':
semiexpress.cpp:9:20: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
    9 |     int n,m,K;scanf("%i%i%i",&n,&m,&K);
      |               ~~~~~^~~~~~~~~~~~~~~~~~~
semiexpress.cpp:11:19: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   11 |     ll A,B,C;scanf("%lld%lld%lld",&A,&B,&C);
      |              ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
semiexpress.cpp:12:15: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   12 |     ll T;scanf("%lld",&T);
      |          ~~~~~^~~~~~~~~~~
semiexpress.cpp:13:43: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   13 |     ll a[m+10];for(int i=1;i<=m;i++) scanf("%lld",&a[i]);
      |                                      ~~~~~^~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...