제출 #602930

#제출 시각아이디문제언어결과실행 시간메모리
602930berrKpart (eJOI21_kpart)C++17
100 / 100
1880 ms391796 KiB
#include <bits/stdc++.h>
using namespace std;
int knp[1005][100015];
int pre[1005], a[1005];
int32_t main()
{
    ios_base::sync_with_stdio(false); cin.tie(0);
    int t; cin>>t; 
    int p=0;
    while(t--)
    {
 
        int n; cin>>n;
     
        for(int i=1; i<=n; i++)
        {
            cin>>a[i]; 
            pre[i]=pre[i-1]+a[i];
        }
 
 
 
        for(int i=0; i<=pre[n]; i++) knp[0][i]=0;
 
        for(int i=1; i<=n; i++)
        {
            for(int l=pre[n]-a[i]; l>0; l--)
            {
                knp[i][a[i]+l] = max(knp[i-1][a[i]+l], knp[i-1][l]);

            }
            knp[i][a[i]]=i; 
        
            for (int j = a[i]-1; j > 0; j--) knp[i][j] = knp[i - 1][j];
 
        }
    

        vector<int> ans;
        for (int i=2; i<=n; i++)
        {
            int flag=1;
            for (int j=1; j<=n-i+1; j++)
            {
                int sum = pre[j+i-1];
                sum-=pre[j-1];
            
                if (sum%2==1||knp[j+i-1][sum/2]<j) flag = 0;
            }
            if (flag == 1) ans.push_back(i);
        }

        cout<<ans.size()<<" ";
        for(auto i: ans) cout<<i<<" ";
            cout<<"\n";
 
    }
   
}

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

Main.cpp: In function 'int32_t main()':
Main.cpp:9:9: warning: unused variable 'p' [-Wunused-variable]
    9 |     int p=0;
      |         ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...