제출 #394769

#제출 시각아이디문제언어결과실행 시간메모리
394769juggernaut수열 (APIO14_sequence)C++14
0 / 100
57 ms2108 KiB
#include<bits/stdc++.h>
//#include<bits/extc++.h>
#define fr first
#define sc second
using namespace std;
void usaco(string s){freopen((s+".in").c_str(),"r",stdin);freopen((s+".out").c_str(),"w",stdout);}
//using namespace __gnu_pbds;
typedef long long ll;
//template<class T>using ordered_set=tree<T,null_type,less<T>,rb_tree_tag,tree_order_statistics_node_update>;
template<class T>void umin(T &a,T b){if(b<a)a=b;}
template<class T>void umax(T &a,T b){if(a<b)a=b;}
#ifdef IOI2021SG
    #define printl(args...)printf(args)
#else
    #define printl(args...)((void)0)
#endif
int n,k,a[100005];
ll pref[100005];
bool en[100005];
int main(){
    scanf("%d%d",&n,&k);
    for(int i=1;i<=n;i++)scanf("%d",&a[i]),pref[i]=pref[i-1]+a[i];
    en[n]=true;
    ll ans=0;
    vector<int>v;
    while(k--){
        ll mx=-1;
        int id;
        int last=1;
        for(int i=1;i<=n;i++)
            if(en[i]){
                ll sum=pref[i]-pref[last-1];
                ll prf=0;
                for(int j=last;j<i;j++){
                    prf+=a[j];
                    sum-=a[j];
                    if(prf*sum>mx){
                        mx=prf*sum;
                        id=j;
                    }
                }
                last=i+1;
            }
        ans+=mx;
        en[id]=true;
        v.push_back(id);
    }
    printf("%lld\n",ans);
    for(int x:v)printf("%d ",x);
}

컴파일 시 표준 에러 (stderr) 메시지

sequence.cpp: In function 'void usaco(std::string)':
sequence.cpp:6:29: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result]
    6 | void usaco(string s){freopen((s+".in").c_str(),"r",stdin);freopen((s+".out").c_str(),"w",stdout);}
      |                      ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
sequence.cpp:6:66: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result]
    6 | void usaco(string s){freopen((s+".in").c_str(),"r",stdin);freopen((s+".out").c_str(),"w",stdout);}
      |                                                           ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
sequence.cpp: In function 'int main()':
sequence.cpp:21:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   21 |     scanf("%d%d",&n,&k);
      |     ~~~~~^~~~~~~~~~~~~~
sequence.cpp:22:31: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   22 |     for(int i=1;i<=n;i++)scanf("%d",&a[i]),pref[i]=pref[i-1]+a[i];
      |                          ~~~~~^~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...