题目描述

Farmer John希望给他的N(1<=N<=100,000)只奶牛拍照片,这样他就可以向他的朋友炫耀他的奶牛.

这N只奶牛被标号为1..N. 在照相的那一天,奶牛们排成了一排.其中第i个位置上是标号为 ci(1<=ci<=N)c_i(1<=c_i<=N)ci​(1<=ci​<=N) 的奶牛.

对于奶牛的站位,Farmer John有他自己的想法. FJ是这么想的,标号为i(1<=i<=n-1)的奶牛只能站在标号为i+1的奶牛的左边,而标号为N的奶牛只能站在标号为1的奶牛的左边.当然,没有牛可以站在队列中最左边的奶牛的左边了.也就是说,最左边的奶牛编号是随意的.

这些奶牛都非常的饿,急切的希望吃到FJ承诺的在拍照后的大餐,所以FJ想尽快的拍照.奶牛们的方向感非常的不好,所以FJ每一分钟只可以选择相邻的两只奶牛然后让他们交换位置.FJ最小需要多少时间就能使奶牛站成一个可以接受的序列?

比方说一个有5只奶牛的例子,一开始序列是这样的: 左边 右边 3 5 4 2 1

第一分钟,FJ可以交换第二队奶牛(即5和4),交换后的队列: 3 4 5 2 1

第二分钟,FJ交换最右边的一对,序列变成这样: 3 4 5 1 2

这样,只用了2分钟,就是序列变为了一个FJ所希望的序列.

输入输出格式

输入格式:

第1行:一个单独的数N 第2到n+1行:第i+1行上的数表示站在第i的位置上的奶牛的编号(即 cic_ici​ ).

输出格式:

一个整数,表示是奶牛的序列变为一个合法的序列的最小花费时间.

输入输出样例

输入样例#1:

5
3
5
4
2
1
输出样例#1:

2

提交地址:Luogu4545

众多USACO搜索题中的一股小清流;
刚看题:裸的逆序对淼淼淼淼;
笑容逐渐凝固:woc这没我想的那么简单...
我们的逆序对可以解决从1~n的排列问题, 但是这道题显然不是从1~n的排列;
那怎么办呢?
例如234561的序列, 逆序对个数为5, 这表明我们要换5次,是吗?显然不是, 我们一次都不用换;
那我们该怎样考虑这个问题呢?
我们可以把1想象成7!这样逆序对为0,且满足题意;
再举个例子, 3456721;
原始逆序对为11个;我们把1想象成8, 逆序对为5;
我们把2想象成9,逆序对为1;
这样我们保证了之前相对小的数, 在改变了它之后仍然相对小;
例如3456721, 改为3456728, 改为3456798, 还保证了"2">"1", 保证了相对大小不变, 我们改变的只是中间的"断点"; 意思是,我们从小到大枚举一个数假设它最大, 意思是它就是序列的一个结尾;
那我们怎样快速地求出修改之后的逆序对的数量呢?
显然最小的数产生的逆序对数量等于pos[i]-1, 就是它位置减一;
它成为最大值之后会增加n-pos[i]个新的逆序对;
所以我们可以先求出原先序列的逆序对, 然后枚举最小的数为最大数, 修改逆序对的数量, 然后取min;
代码奉上:
 #include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std; inline int read()
{
int res=;bool fl=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')fl=;ch=getchar();
}while(isdigit(ch)){res=(res<<)+(res<<)+(ch-'');ch=getchar();
}return fl?-res:res;
} int n;
int a[];
int pos[]; int t[];
inline int lowbit(int x){return x & -x;} inline void add(int x, int y){while(x <= n){t[x]+=y;x+=lowbit(x);}} inline int query(int x){int ans=;while(x!=)ans+=t[x], x-=lowbit(x);return ans;} long long ans;
long long best; int main()
{
n = read();
for (register int i = ; i <= n ; i ++) a[i] = read(), pos[a[i]] = i; for (register int i = n ; i >= ; i --)
{
ans += query(a[i] - );
add(a[i], );
} best = ans; for (register int i = ; i <= n ; i ++)
{
best = best - (pos[i] - ) + (n - pos[i]);
ans = min(ans, best);
}
cout << ans << endl;
return ;
}
 

[USACO10NOV]奶牛的图片Cow Photographs的更多相关文章

  1. [USACO10NOV]奶牛的图片Cow Photographs 树状数组 递推

    Code: #include<cstdio> #include<algorithm> #include<string> #include<cstring> ...

  2. 【luoguP2995】[USACO10NOV]牛的照片Cow Photographs

    题目链接 首先求出原序列的逆序对个数, 然后考虑每次将目标序列最前面的数放在最后,即最小的数变为最大 设最小数的位置是\(p\),那么逆序对的个数增加了\(n-p\),减少了\(p-1\) #incl ...

  3. Bzoj 2058: [Usaco2010 Nov]Cow Photographs 题解

    2058: [Usaco2010 Nov]Cow Photographs Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 190  Solved: 104[ ...

  4. USACO 奶牛抗议 Generic Cow Protests

    USACO 奶牛抗议 Generic Cow Protests Description 约翰家的N头奶牛聚集在一起,排成一列,正在进行一项抗议活动.第i头奶牛的理智度 为Ai,Ai可能是负数.约翰希望 ...

  5. P2986 [USACO10MAR]伟大的奶牛聚集Great Cow Gat…

    题目描述 Bessie is planning the annual Great Cow Gathering for cows all across the country and, of cours ...

  6. 洛谷 P2986 [USACO10MAR]伟大的奶牛聚集Great Cow Gat…(树规)

    题目描述 Bessie is planning the annual Great Cow Gathering for cows all across the country and, of cours ...

  7. [USACO10MAR]伟大的奶牛聚集Great Cow Gat…

    题目描述 Bessie is planning the annual Great Cow Gathering for cows all across the country and, of cours ...

  8. 【题解】Luogu p2986 [USACO10MAR]伟大的奶牛聚集Great Cow Gat 树型dp

    题目描述 Bessie is planning the annual Great Cow Gathering for cows all across the country and, of cours ...

  9. P2857 [USACO06FEB]稳定奶牛分配Steady Cow Assignment

    题目描述 Farmer John's N (1 <= N <= 1000) cows each reside in one of B (1 <= B <= 20) barns ...

随机推荐

  1. 使用java程序作为celery的工作节点

    celery是python实现的分布式调度框架,有时候想用celery去调用java服务,正好有一个celery-java的库可以使用,能达到这个效果,记录一下: 先添加依赖: <depende ...

  2. CabloyJS带你轻松走进NodeJS全栈开发-免费课程 作者亲授

    课程说明 B站直播 为回馈新老同学对开源框架CabloyJS的支持与厚爱,快速而轻松的开启NodeJS全栈开发之旅.2019年9月5日至9月11日在B站开启了一波免费直播培训课程 课程信息,请点击链接 ...

  3. 取html里的img和去html标签

    C#  : public string RemoveHTML(string html) { html = Regex.Replace(html, @"<script[^>]*?& ...

  4. 02 (H5*) Vue第二天

    目录: 1:全局过滤器的使用 2:局部过滤器 3:自定义键盘码 4:自定义指令 5:自定义私有指令 6:Vue生命周期. 7:网络请求 1:全局过滤器的使用 Vue.filter("msgF ...

  5. .NetCore 网站DELETE请求错误405.0 - Method Not Allowed 因为使用了无效方法

    .netCore网站Delete请求405错误 解决方案 1:在启用或关闭Windows功能 –> Internet Information Services 关闭WebDAV发布(这种方式可能 ...

  6. Hadoop 之 分布式缓存的原理和方法——DistributedCache

    1.什么时Hadoop的分布式缓存 答:在执行MapReduce时,可能Mapper之间需要共享一些信息,如果信息量不大,可以将其从HDFS中加载到内存中,这就是Hadoop分布式缓存机制. 2.如何 ...

  7. Spring Boot(二) 配置文件

    文章导航-readme 一.配置Spring Boot热部署     技术的发展总是因为人们想偷懒的心理,如果我们不想每次修改了代码,都必须重启一下服务器,并重新运行代码.那么可以配置一下热部署.有了 ...

  8. Spring boot 官网学习笔记 - Configuration Class(@import)

    推荐使用 Java-based configuration ,也可以使用xml we generally recommend that your primary source be a single ...

  9. springboot系列之03-使用IDEA完成第一个示例程序

    未经允许,不得转载 原作者:字母哥博客 本文完整系列出自:springboot深入浅出系列 一.使用IntellijIDEA建立第一个spring boot 项目 通常只有专业版付费版才默认带有Spr ...

  10. 算法题解:最大或最小的K个数(海量数据Top K问题)

    题目 输入 n 个整数,找出其中最小的 k 个数.例如输入4.5.1.6.2.7.3.8 这8个数字,则最小的4个数字是1.2.3.4. 初窥 这道题最简单的思路莫过于把输入的 n 个整数排序,排序之 ...