[JZO6401]:Time(贪心+树状数组)
题目描述
  小$A$现在有一个长度为$n$的序列$\{x_i\}$,但是小$A$认为这个序列不够优美。
  小$A$认为一个序列是优美的,当且仅当存在$k\in [1,n]$,满足:
$$x_1\leqslant x_2\leqslant...\leqslant x_k\geqslant x_{k+1}\geqslant...\geqslant x_n$$
  现在小$A$可以进行若干次操作,每次可以交换序列中相邻的两个项,现在他想知道最少操作多少次之后能够使序列变为优美的。
输入格式
  第一行一个正整数$n$,表示序列的长度。
  接下来一行$n$个整数,表示初始的序列。
输出格式
输出一行一个整数,表示最少需要的操作次数。
样例
样例输入:
5
3 4 5 1 2
样例输出:
1
数据范围与提示
  对于$30\%$的数据,$n\leqslant 12$
  对于$60\%$的数据,$n\leqslant 100,000$,$a_i$互不相同
  对于$100\%$的数据,$n,a_i\leqslant 100,000$
题解
考虑贪心,一定是挨个将最小的数移到两端不劣。
至于过程直接用树状数组维护就好了,交换次数就是一侧比它大的数的个数。
时间复杂度:$\Theta(n\log n)$。
期望得分:$100$分。
实际得分:$100$分。
代码时刻
#include<bits/stdc++.h>
using namespace std;
int n;
int a[100001],cnt;
int tr[100001];
long long ans;
vector<int> vec[100001];
int lowbit(int x){return x&-x;}
void add(int x){for(int i=x;i<=n;i+=lowbit(i))tr[i]++;}
void del(int x){for(int i=x;i<=n;i+=lowbit(i))tr[i]--;}
int ask(int x){int res=0;for(int i=x;i;i-=lowbit(i))res+=tr[i];return res;}
int main()
{
scanf("%d",&n);cnt=n;
for(int i=1;i<=n;i++)scanf("%d",&a[i]);
for(int i=1;i<=n;i++){add(i);vec[a[i]].push_back(i);}
for(int i=1;i<=n;i++)
for(int j=0;j<vec[i].size();j++)
{
int x=ask(vec[i][j]-1),y=cnt-x-1;
ans+=min(x,(int)(y-vec[i].size()+j+1));
del(vec[i][j]);cnt--;
}
printf("%lld",ans);
return 0;
}
rp++
[JZO6401]:Time(贪心+树状数组)的更多相关文章
- 【bzoj4240】有趣的家庭菜园  贪心+树状数组
		题目描述 对家庭菜园有兴趣的JOI君每年在自家的田地中种植一种叫做IOI草的植物.JOI君的田地沿东西方向被划分为N个区域,由西到东标号为1~N.IOI草一共有N株,每个区域种植着一株.在第i个区域种 ... 
- 贪心+树状数组维护一下   Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined) D
		http://codeforces.com/contest/724/problem/D 题目大意:给你一个串,从串中挑选字符,挑选是有条件的,按照这个条件所挑选出来的字符集合sort一定是最后选择当中 ... 
- D 洛谷 P3602 Koishi Loves Segments [贪心 树状数组+堆]
		题目描述 Koishi喜欢线段. 她的条线段都能表示成数轴上的某个闭区间.Koishi喜欢在把所有线段都放在数轴上,然后数出某些点被多少线段覆盖了. Flandre看她和线段玩得很起开心,就抛给她一个 ... 
- [BZOJ4240]有趣的家庭菜园(贪心+树状数组)
		最后数列一定是单峰的,问题就是最小化最后的位置序列的逆序对数. 从大到小加数,每次贪心看放左边和右边哪个产生的逆序对数更少,树状数组即可. 由于大数放哪对小数不产生影响,所以正确性显然. 注意相同数之 ... 
- [P4064][JXOI2017]加法(贪心+树状数组+堆)
		题目描述 可怜有一个长度为 n 的正整数序列 A,但是她觉得 A 中的数字太小了,这让她很不开心. 于是她选择了 m 个区间 [li, ri] 和两个正整数 a, k.她打算从这 m 个区间里选出恰好 ... 
- [luoguP2672] 推销员(贪心 + 树状数组 + 优先队列)
		传送门 贪心...蒟蒻证明不会... 每一次找最大的即可,找出一次最大的,数列会分为左右两边,左边用stl优先队列维护,右边用树状数组维护.. (线段树超时了....) 代码 #include < ... 
- codeforces 1249 D2 Too Many Segments (hard version) 贪心+树状数组
		题意 给定n个线段,线段可以相交,第\(i\)个线段覆盖的区间为\([l_i,r_i]\),问最少删除多少个线段让覆盖每个点的线段数量小于等于k. 分析 从左往右扫每个点\(x\),若覆盖点\(x\) ... 
- UVALive 6911---Double Swords(贪心+树状数组(或集合))
		题目链接 https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_ ... 
- 【HOJ2430】【贪心+树状数组】 Counting the algorithms
		As most of the ACMers, wy's next target is algorithms, too. wy is clever, so he can learn most of th ... 
随机推荐
- monggoDB添加到windows服务
			----------------mongoDB安装------------------------------- 1.下载mongoDB安装包安装完毕后,配置环境变量 D:\Program Files ... 
- 将Abp的UnitTest中的InMemory改为SQLite in memory
			添加nuget包 Microsoft.EntityFrameworkCore.Sqlite 添加ServiceCollectionRegistrarSqlite public static class ... 
- 命名空间System.IO
			基本介绍:System.IO 命名空间提供读写文件和数据流的类型.基本文件和目录支持的类型. 原文:http://blog.sina.com.cn/s/blog_48a45b950100erhz.ht ... 
- 谈谈对this的指向问题
			普通函数中:this——window 定时器:this——window 构造函数中:this——当前实例化的对象 事件处理函数:this——事件触发对象 
- 第六篇 CSS样式 背景、背景图、文本、链接
			元素背景.文本(字体)样式.链接 这里我们只学习常用的一些,更多的扩展就要同学们自己去了解,或者下方评论. 这里我们为了简便,用的是CSS的内嵌形式. 元素背景: 我们写模块的时候,有的时候为了区 ... 
- C语言字符串函数总结
			原文链接 函数名: stpcpy 功 能: 拷贝一个字符串到另一个 用 法: char *stpcpy(char *destin, char *source); 程序例: #include <s ... 
- 1.SpringBoot整合Mybatis(CRUD的实现)
			准备工具:IDEA jdk1.8 Navicat for MySQL Postman 一.新建Project 选择依赖:mybatis Web Mysql JDBC 项目结构 pom依赖: & ... 
- 浙大数据结构课后习题 练习二 7-3 Pop Sequence (25 分)
			Given a stack which can keep M numbers at most. Push N numbers in the order of 1, 2, 3, ..., N and p ... 
- Some notes of An Insider's Guide to TOEFL iBT
			尽早把托福这个坑填上方是正道,在正式上托福课之前阅读了这本Guide,颇受启发——只要是考试,总是有固定的方法的= = An Insider's Guide to TOEFL iBT It is NO ... 
- Codeforces Round #581 (Div. 2)  B. Mislove Has Lost an Array (贪心)
			B. Mislove Has Lost an Array time limit per test1 second memory limit per test256 megabytes inputsta ... 
