Duals (easy version) solution exceeding memory limit
Difference between en2 and en3, changed 4 character(s)
~~~~~↵
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://mirror.codeforces.com/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)