AtCoder Beginner Contest 081 D

2 篇文章 0 订阅
1 篇文章 0 订阅

D Non-decreasing
题意:给N个数,有操作f(a,b) 把第a个数的值加到第b个数上。求一个小于2N的操作序列,使给出的序列变成非递减序列。
题解:当序列为非负序列时,通过a[i+1]+=a[i]构造;
当为非正序列时a[i]+=a[i+1];
所以先用N个操作(加绝对值最大的数)变成非正/非负序列,然后按照上面的构造方法构造即可。
注意边界。

    #include<bits/stdc++.h>
    using namespace std;
    typedef long long ll;
    typedef long double db;
    typedef pair<int,int> pii;
    typedef vector<int> vi;
    #define de(x) cout << #x << "=" << x << endl
    #define rep(i,a,b) for(int i=a;i<(b);++i)
    #define per(i,a,b) for(int i=b-1;i>=(a);i--) 
    #define all(x) (x).begin(),(x).end()
    #define sz(x) (int)(x).size()
    #define mp make_pair
    #define pb push_back
    #define fi first
    #define se second
    #define lb(x) (x&-(x))
    const int N = 101010;
    int a[200];
    int main(){
        int maxx=INT_MIN;
        int maxxi,minni;
        int minn=INT_MAX;
        int n;
        cin>>n;
        rep(i,0,n) 
        {
            scanf("%d",&a[i]);
            if(a[i]>maxx)
            {
                maxx=a[i];
                maxxi=i;
            }
            if(a[i]<minn)
            {
                minn=min(minn,a[i]);
                minni=i;
            }
        }


        printf("%d\n",n+n-1);
        if(maxx+minn>=0)
        {    
             rep(i,0,n)
             {
                printf("%d %d\n",maxxi+1,i+1);
                a[i]+=maxx;
             }

    //       rep(i,0,n) cout<<a[i]<<" ";cout<<endl;
            rep(i,0,n-1)
            {
                printf("%d %d\n",i+1,i+2);
                a[i+1]+=a[i];
            }
        }
        else
        {
             rep(i,0,n)
             {
                printf("%d %d\n",minni+1,i+1);
                a[i]+=minn;
             }      
    //       rep(i,0,n) cout<<a[i]<<" ";cout<<endl;     
            per(i,0,n-1)
            {
                printf("%d %d\n",i+2,i+1);
                a[i]+=a[i+1];
            }
        }



        return 0;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值