题目描述

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. FBCTF平台安装

    一言难尽 = =开始不知道FBCTF只能安装在Ubuntu,在本地搭建半天好不容易弄起了PHP环境,打开错误,后来才知道只能在Ubuntu 14.04 LTS下安装= = FBCTF是Facebook ...

  2. 首次接触flask遇到socket.error: [Errno 10013] 报错

    解决方案: 发现是因为端口5000被占用了,设置一个其他port就行:app.run(port=5050)

  3. 2018年蓝桥杯java b组第三题

    标题:复数幂 设i为虚数单位.对于任意正整数n,(2+3i)^n 的实部和虚部都是整数.求 (2+3i)^123456 等于多少? 即(2+3i)的123456次幂,这个数字很大,要求精确表示. 答案 ...

  4. 基于MFCC的语音数据特征提取概述

    1. 概述 语音是人类之间沟通交流的最直接也是最快捷方便的一种手段,而实现人类与计算机之间畅通无阻的语音交流,一直是人类追求的一个梦想. 伴随着移动智能设备的普及,各家移动设备的厂家也开始在自家的设备 ...

  5. alpha测试和beta测试的区别

    alpha测试版,有点相当于内部测试,一般开发人员在场   ,是由用户做测试,但开发人员在场,一般是请用户到开发现场去测试  beta测试版,完全交给用户,由用户做测试,返回测试报告,相当于发行前的一 ...

  6. 【系统设计】分布式唯一ID生成方案总结

    目录 分布式系统中唯一ID生成方案 1. 唯一ID简介 2. 全局ID常见生成方案 2.1 UUID生成 2.2 数据库生成 2.3 Redis生成 2.4 利用zookeeper生成 2.5 雪花算 ...

  7. Maven 梳理 - 核心概念

    Maven坐标 依赖配置 依赖范围 依赖范围scope用来控制依赖和编译,测试,运行的classpath的关系. 主要的是三种依赖关系如下: 1.compile: 默认编译依赖范围.对于编译,测试,运 ...

  8. Shell之StdI/O和Pipe

    目录 Shell之StdI/O和Pipe 参考 StdI/O重定向 Pipe 常用组合 Shell之StdI/O和Pipe

  9. MySql5.5安装步骤及MySql_Front视图配置

    一.下载文件 有需要的朋友,请自行到百度云下载 链接:https://pan.baidu.com/s/13Cf1VohMz_a0czBI05UqJg 提取码:cmyq 二.安装MySql 2.1.运行 ...

  10. 从零开始入门 K8s | 可观测性:你的应用健康吗?

    作者 | 莫源 阿里巴巴技术专家 一.需求来源 首先来看一下,整个需求的来源:当把应用迁移到 Kubernetes 之后,要如何去保障应用的健康与稳定呢?其实很简单,可以从两个方面来进行增强: 首先是 ...