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

    https://www.luogu.org/problem/show?pid=1774

    题目描述

    破解了符文之语,小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。

    ans要long long ,注意离散化.

     1 #include <algorithm>
     2 #include <cstdio>
     3 #define LL long long
     4 
     5 using namespace std;
     6 
     7 const int N(5*1e5+15);
     8 LL n,ans;
     9 struct Node
    10 {
    11     LL num,mark;
    12 }node[N];
    13 bool cmp(Node a,Node b)
    14 {
    15     if(a.num==b.num) return a.mark>b.mark;
    16     return a.num>b.num;
    17 } 
    18 
    19 int sum[N];
    20 #define lowbit(x) (x&((~x)+1))
    21 void up(LL x)
    22 {
    23     for(;x<=N;x+=lowbit(x)) sum[x]++;
    24 }
    25 LL query(LL x)
    26 {
    27     LL ret=0;
    28     for(;x;x-=lowbit(x)) ret+=sum[x];
    29     return ret;
    30 }
    31 
    32 int main()
    33 {
    34     scanf("%lld",&n);
    35     for(LL i=1;i<=n;i++)
    36         scanf("%lld",&node[i].num),node[i].mark=i;
    37     sort(node+1,node+n+1,cmp);
    38     for(LL i=1;i<=n;up(node[i++].mark))
    39         ans+=query(node[i].mark);
    40     printf("%lld",ans);
    41     return 0;
    42 }
    ——每当你想要放弃的时候,就想想是为了什么才一路坚持到现在。
  • 相关阅读:
    <转>c#调用C++DLL类型转换
    <转>CB2010使用一段时间总结。(Ansi>Unicode)
    Sql的自定义聚合函数,挺费劲。
    关于 MSDN 说 Lock 应该用private 对象锁定的测试。
    热门JQuery插件
    偶然发现 RouteDebuge 的作者是一个超牛的家伙。
    jquery.query 插件的设计问题。
    JQuery UI 调整笔记
    JQuery tr:visible IE8 失效.
    CS0016 一个解决方案:
  • 原文地址:https://www.cnblogs.com/Shy-key/p/7204619.html
Copyright © 2011-2022 走看看