传送门

首先枚举最大值,两边分别求逆序对的做法是错误的,这里是来自战神的hack数据

1 2 100 99 98 3 97 96 95 94 93 92 91

显然3应该跨过最大值到左边去,所以这个做法就没有正确性了

然后正解:

发现最小值一定会被移到最边上,而且因为它最小,就不会再有数跨过它移动

所以这东西没有后效性,且移动后会形成子问题

所以不断取最小值,贪心地取次数最小的方向移动,然后把它删了就行了

  • 所以……要交换序列里的元素,使它们成某种顺序的时候,可以考虑「什么元素不可被跨越」或者「什么元素一定会被移动到什么位置」,然后设法固定这些元素,其余的转化为子问题?

Code:

#include <bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
#define N 100010
#define ll long long
#define reg register int
#define fir first
#define sec second
#define make make_pair
//#define int long long char buf[1<<21], *p1=buf, *p2=buf;
#define getchar() (p1==p2&&(p2=(p1=buf)+fread(buf, 1, 1<<21, stdin)), p1==p2?EOF:*p1++)
inline int read() {
int ans=0, f=1; char c=getchar();
while (!isdigit(c)) {if (c=='-') f=-f; c=getchar();}
while (isdigit(c)) {ans=(ans<<3)+(ans<<1)+(c^48); c=getchar();}
return ans*f;
} int n;
int x[N]; namespace task1{
int uni[N], usize, lim;
int ans=INF, a[N];
inline void upd(int i) {for (; i<=lim; i+=i&-i) ++a[i];}
inline int query(int i) {int ans=0; for (; i; i-=i&-i) ans+=a[i]; return ans;}
void solve() {
for (int i=1; i<=n; ++i) uni[i]=x[i];
sort(uni+1, uni+n+1);
usize=unique(uni+1, uni+n+1)-uni-1; lim=usize+2;
for (int i=1; i<=n; ++i) x[i]=lower_bound(uni+1, uni+usize+1, x[i])-uni+1;
for (int i=1,cnt; i<=n; ++i) {
memset(a+1, 0, sizeof(int)*lim);
cnt=0;
for (int j=i; j; --j) {
cnt+=query(x[j]-1);
upd(x[j]);
}
memset(a+1, 0, sizeof(int)*lim);
for (int j=i+1; j<=n; ++j) {
cnt+=query(x[j]-1);
upd(x[j]);
}
ans=min(ans, cnt);
}
printf("%d\n", ans);
exit(0);
}
} namespace task{
int a[N]; ll ans;
pair<int, int> s[N];
inline void upd(int i) {for (; i<=n; i+=i&-i) ++a[i];}
inline int query(int i) {int ans=0; for (; i; i-=i&-i) ans+=a[i]; return ans;}
inline void del(int i) {for (; i<=n; i+=i&-i) --a[i];}
void solve() {
for (int i=1; i<=n; ++i) upd(i);
for (int i=1; i<=n; ++i) s[i]=make(x[i], i);
sort(s+1, s+n+1);
for (reg pos1=1,pos2=1,top=1,t1,t2; top<=n; pos1=pos2=++top) {
while (top+1<=n && s[pos1].fir==s[top+1].fir) ++top;
pos2=top;
while (pos1<pos2) {
t1=min(query(s[pos1].sec-1), query(n)-query(s[pos1].sec));
t2=min(query(s[pos2].sec-1), query(n)-query(s[pos2].sec));
if (t1<t2) ans+=t1, del(s[pos1++].sec);
else ans+=t2, del(s[pos2--].sec);
}
ans+=min(query(s[pos1].sec-1), query(n)-query(s[pos1].sec)), del(s[pos1].sec);
}
printf("%lld\n", ans);
exit(0);
}
} signed main()
{
n=read();
for (int i=1; i<=n; ++i) x[i]=read();
task::solve(); return 0;
}

题解 Time的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. 使用 Cron4j 表达式 在 Solon 里开发定时任务

    cron4j 是一个轻量级的Java任务调度工具.cron4j-solon-plugin 是 solon 对 cron4j 的适配插件 添加 maven 引用 <dependency> & ...

  2. ARTS第八周

    1.Algorithm:每周至少做一个 leetcode 的算法题2.Review:阅读并点评至少一篇英文技术文章3.Tip:学习至少一个技术技巧4.Share:分享一篇有观点和思考的技术文章 以下是 ...

  3. Kubernetes 1.13.3 部署 Prometheus+Grafana-7.5.2(最新版本踩坑)

    本教程直接在 Kubernetes 1.13.3 版本上安装 Prometheus 和 Grafana-7.5.2,至于它们的原理和概念就不再赘述,这里就直接开始操作. Git 下载相关 YAML 文 ...

  4. PYTHON startswith (endswith类似)

    Python startswith()方法Python startswith() 方法用于检查字符串是否是以指定子字符串开头,如果是则返回 True,否则返回 False.如果参数 beg 和 end ...

  5. [刘阳Java]_步步窥探JS变量作用域

    今天的这个文章题目名称甚是让人会突发异想.JS变量作用域是务必需要搞懂的,单从面试过程就会让面试者烧脑壳.所以,我们还是写一篇关于JS变量作用域的技术专题,让所有小伙伴能够借此文章去整理JS的基础学习 ...

  6. 【LeetCode】151. 翻转字符串里的单词(剑指offer 58-I)

    151. 翻转字符串里的单词 知识点:字符串:双指针 题目描述 给你一个字符串 s ,逐个翻转字符串中的所有 单词 . 单词 是由非空格字符组成的字符串.s 中使用至少一个空格将字符串中的 单词 分隔 ...

  7. Three.js-任意平面的镜像矩阵

    1. 什么是镜像变换 直接看下面这张图: 这张图很好的诠释了镜像变化,关于y轴的变化,关于x轴的变化.这种关于任意轴的变化,就是镜像了. 2d下的镜像矩阵变化 我们以图像关于Y轴镜像为例子:原图形和结 ...

  8. python 装饰函数2

    #!/usr/bin/env python3 # -*- coding: utf-8 -*- """ Created on Tue May 5 21:40:49 2020 ...

  9. PL SQL Developer 13连接Oracle数据库并导出数据

    下载 并安装 PL SQL Developer 13,默认支持中文语言 ============================= 注册码: product code: 4vkjwhfeh3ufnqn ...

  10. Java大整形BigInteger的用法

    基本类型int有32位,范围是:[-2147483648, 2147483647](正负21亿多) 基本类型long有64位,范围是:[-9223372036854775808, 9223372036 ...