zoukankan      html  css  js  c++  java
  • 洛谷 P1774 最接近神的人_NOI导刊2010提高(02)

    题目描述

    破解了符文之语,小FF开启了通往地下的道路。当他走到最底层时,发现正前方有一扇巨石门,门上雕刻着一幅古代人进行某种活动的图案。而石门上方用古代文写着“神的殿堂”。小FF猜想里面应该就有王室的遗产了。但现在的问题是如何打开这扇门……

    仔细研究后,他发现门上的图案大概是说:古代人认为只有智者才是最容易接近神明的。而最聪明的人往往通过一种仪式选拔出来。仪式大概是指,即将隐退的智者为他的候选人写下一串无序的数字,并让他们进行一种操作,即交换序列中相邻的两个元素。而用最少的交换次数使原序列变成不下降序列的人即是下一任智者。

    小FF发现门上同样有着n个数字。于是他认为打开这扇门的秘诀就是找到让这个序列变成不下降序列所需要的最小次数。但小FF不会……只好又找到了你,并答应事成之后与你三七分……

    输入输出格式

    输入格式:

    第一行为一个整数n,表示序列长度

    第二行为n个整数,表示序列中每个元素。

    输出格式:

    一个整数ans,即最少操作次数。

    输入输出样例

    输入样例#1:
    4
    2 8 0 3
    
    输出样例#1:
    3
       样例说明:开始序列为2 8 0 3,目标序列为0 2 3 8,可进行三次操作的目标序列:
        1.Swap (8,0):2  0  8  3
        2.Swap (2,0):0  2  8  3
        3.Swap (8,3):0  2  3  8
    

    说明

    对于30%的数据1≤n≤10^4。

    对于100%的数据1≤n≤5*10^5;

    -maxlongint≤A[i]≤maxlongint。

    树状数组

    相当于求逆序对

    屠龙宝刀点击就送

    #include <algorithm>
    #include <ctype.h>
    #include <cstdio>
    
    const int N = 5*1e5+5;
    typedef long long LL;
    using namespace std;
    inline void Read(LL &x)
    {
        bool f=0;
        register char ch=getchar();
        for(x=0;!isdigit(ch);ch=getchar()) if(ch=='-') f=1;
        for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';
        x=f?-x:x;
    }
    struct node
    {
        LL val;
        int pos;
        bool operator<(node a)const
        {
            if(val==a.val) return pos>a.pos;
            else return val>a.val;
        }
    }a[N];
    LL tag[N],n,ans;
    inline LL lowbit(LL x) {return x&(-x);}
    inline LL ask(LL x)
    {
        LL sum=0;
        for(;x;x-=lowbit(x)) sum+=tag[x];
        return sum;
    }
    inline void modify(int x,int y)
    {
        for(;x<=n;x+=lowbit(x))
            tag[x]+=y;
    }
    int main()
    {
        Read(n);
        for(int i=1;i<=n;++i)
        {
            Read(a[i].val);
            a[i].pos=i;
        }
        sort(a+1,a+1+n);
        for(int i=1;i<=n;++i)
        {
            if(i!=1) ans+=ask(a[i].pos-1);
            modify(a[i].pos,1);
        }
        printf("%lld
    ",ans);
        return 0;
    }
    我们都在命运之湖上荡舟划桨,波浪起伏着而我们无法逃脱孤航。但是假使我们迷失了方向,波浪将指引我们穿越另一天的曙光。
  • 相关阅读:
    Ubuntu上安装RabbitMQ
    解决tfs工作区绑定问题
    ubuntu装个nginx
    supervisor执行dotnet
    Validate + Boostrap tooltip 表单验证示例
    ASP.NET下跨应用共享Session和使用Redis进行Session托管
    IE下将网页拷贝到剪贴板
    js格式化json格式的日期
    js 时间戳转换
    Windows服务简单使用
  • 原文地址:https://www.cnblogs.com/ruojisun/p/7397968.html
Copyright © 2011-2022 走看看