Duals (easy version) solution exceeding memory limit

Revision en3, by sowdeesnuts, 2025-01-10 20:44:32
void solve()
{
	int n;
    cin>>n;
    vector<int>arr(n);
    for(int i=0;i<n;i++){
        cin>>arr[i];
    }
    int op=0; vector<pair<int,int>>ans;
    while(op<=50){
        vector<int>v1(arr.begin(),arr.end());
        sort(v1.begin(),v1.end());
        int mxele= v1[v1.size()-1];
        int mxelei= max_element(arr.begin(),arr.end())-arr.begin();
        int breakpnt=-1;
        for(int i=1;i<n;i++){
            if(arr[i]<arr[i-1]){
                breakpnt=i; break;
            }
        }
        if(breakpnt==-1) break;
        int req= (arr[breakpnt-1]-arr[breakpnt])/mxele ;
        arr[breakpnt]= arr[breakpnt]+ req*mxele;
        op= op+req;
        while(req--){
            ans.push_back({breakpnt,mxelei});
        }
        if(arr[breakpnt]<arr[breakpnt-1]){
            int extra=arr[breakpnt-1]-arr[breakpnt];
            //cout<<*lower_bound(v1.begin(),v1.end(),extra)<<endl;
            op++;
            int x=*lower_bound(v1.begin(),v1.end(),extra);
            for(int i=0;i<n;i++){
                if(arr[i]==x){
                    ans.push_back({breakpnt,i}); break;
                }
            }
            arr[breakpnt]= arr[breakpnt]+ *lower_bound(v1.begin(),v1.end(),extra);
            //cout<<arr[breakpnt]<<endl;
        }
        if(is_sorted(arr.begin(),arr.end())) break;
     }
    // if(is_sorted(arr.begin(),arr.end())){cout<<"yes"<<endl;}
    // else cout<<"NO"<<endl;
    cout<<ans.size()<<endl;
    for(auto it:ans){
        cout<<it.first+1<<" "<<it.second+1<<endl;
    }
}

The above approach is giving MLE on test case 2 and i cant understand why. Please help

Problem link: https://codeforces.me/problemset/problem/1854/A1

History

 
 
 
 
Revisions
 
 
  Rev. Lang. By When Δ Comment
en3 English sowdeesnuts 2025-01-10 20:44:32 4
en2 English sowdeesnuts 2025-01-10 20:38:48 1943
en1 English sowdeesnuts 2025-01-10 20:37:50 3741 Initial revision (published)