杭州集训Day5
下面是Day5的题目!(其实都咕了好几天了
100+70+40=210.
T1 皇后 XY 的疑难 (1s 512MB)
4 3
4 8
6 5
1 6
T2 快来 pick sxk(1s 512MB)
千古神犇邵徐坤 sxk,他现在利用自己猴子的属相变成了n个会打篮球的分身,每个会打篮球的分身都
有一个鸡儿你真美值,这些分身是乱序的。
你需要将其按鸡儿你真美值从小到大排序,每次你可以将一个分身揪到任意一个位置(某两个分身中
间),代价是你要掉该分身的鸡儿你真美值的毛。
为了不变成sxk这样的聪明"绝顶"的大猴子,你要以尽量少的代价完成这个任务,你需要回答每一次
分身后你会掉的最少毛数。
2.2 输入格式
从文件pick.in中读入数据。
数据的第1行包含一个非负整数t表示sxk分身的次数。
对于每一组数据
第1行包含一个非负整数n表示分身的个数
第2行包含n个数,ai表示第i个分身的鸡儿你真美值
2.3 输出格式
输出到文件pick.out中。
对于每一个询问输出一个整数,表示你最少会掉的毛数
2.4 样例输入
2.6 数据约定
对于30%的数据满足 Σn≤1000.
对于另外30%的数据满足 ai>ai+1.
对于100%的数据满足 Σn≤200000,ai≤107.
#include<bits/stdc++.h>
#define Lowbit(i) (i&(-i))
#define ll long long
using namespace std;
const int N=2e5+1e4;
int n,a[N],b[N],p[N*]; ll w[N];
ll Max(ll x,ll y){
return x>y?x:y;
}
int rd(){
int s=,ff=;
char w=getchar();
while(w<''||w>''){
if(w=='-') ff=-;
w=getchar();
}
while(w>=''&&w<=''){
s=s*+(w-'');
w=getchar();
}
return s*ff;
}
ll Query(int x){ ll maxn=;
for(int i=x;i;i-=Lowbit(i))
maxn=Max(maxn,w[i]);
return maxn;
}
void Add(int x,ll y){
for(int i=x;i<=n;i+=Lowbit(i))
w[i]=Max(w[i],y);
}
int main(){
// freopen("pick.in","r",stdin);
// freopen("pick.out","w",stdout);
int t=rd();
while(t--){ n=rd(); int fla=; ll tot=;
for(int i=;i<=n;i++)
a[i]=rd(),b[i]=a[i],tot+=a[i];
sort(b+,b++n); int ct=;
for(int i=;i<=n;i++){
if(i==||b[i]!=b[i-]) ct++;
p[b[i]]=ct;
}
ll maxn=-1e17;
for(int i=;i<=n;i++){
ll f=Query(p[a[i]]); Add(p[a[i]],f+a[i]);
// for(int j=1;j<i;j++)
// if(a[j]<=a[i])
// f[i]=Max(f[i],f[j]+a[i]);
maxn=Max(maxn,f+a[i]);
}
for(int i=;i<=n;i++) p[a[i]]=,w[i]=;
printf("%lld\n",tot-maxn); continue;
}
return ;
}
对了,我订正的时候用的是树状数组,
因为是求前缀的最大值,所以树状数组是可以的,
记住区间求最大值千万不能用树状数组。
T3 一道另类的前缀和(1s 512MB)



一道数论题,先推式子:
现在求出即可
前20%的n≤2000,预处理下,直接这样模拟就行了
再来看k=0,由二项式定理得:
S(n)就可以算出来了
到这里你就可以获得40分的好成绩,当然还不够,
要继续的话,我得先引出一个推论:
证明如下:
k=1就可以了
很简单对吧,我们继续
先模拟下k=2的情况
以此类推就可以得出最终答案:
就是
发现用到的只有k个,把它和2i滚动地处理出来,但需要求n!
所以时间复杂度为O(n)。
拜拜~
杭州集训Day5的更多相关文章
- Loj #6073.「2017 山东一轮集训 Day5」距离
Loj #6073.「2017 山东一轮集训 Day5」距离 Description 给定一棵 \(n\) 个点的边带权的树,以及一个排列$ p\(,有\)q $个询问,给定点 \(u, v, k\) ...
- 「2017 山东一轮集训 Day5」苹果树
「2017 山东一轮集训 Day5」苹果树 \(n\leq 40\) 折半搜索+矩阵树定理. 没有想到折半搜索. 首先我们先枚举\(k\)个好点,我们让它们一定没有用的.要满足这个条件就要使它只能和坏 ...
- 2019暑期金华集训 Day5 树上数据结构
自闭集训 Day5 树上数据结构 前置知识 点分治 边分治 树链剖分 LCT Top Tree LCT时间复杂度 线段树每次查询是严格\(\log n\)的,然而splay维护连续段的时候,如果每次查 ...
- 2019暑期金华集训 Day5 生成函数
自闭集训 Day5 生成函数 一般生成函数 无脑地把序列变成多项式: \[ \{a_i\}\rightarrow A(x)=\sum_{n} a_nx^n \] 形式幂级数 生成函数是一种形式幂级数. ...
- 「疫期集训day5」火焰
我们就像一把穿刺敌人的利刃,把敌人开肠破肚----凡尔登高地前气势汹汹的德军 今天没有考试,挺好,有时间自己做题了 今天主要复习+学习了数据结构,列了个表: 已完成:单调队列,线段树,set/vect ...
- 2022寒假集训day5
day5 五道栈的题加上字符串. 单调队列. T1 表达式括号匹配 洛谷P1739 题目描述 假设一个表达式有英文字母(小写).运算符(+,-,*,/)和左右小(圆)括号构成,以"@&q ...
- [日常训练]常州集训day5
T1 Description 小$W$和小$M$一起玩拼图游戏啦~ 小$M$给小$M$一张$N$个点的图,有$M$条可选无向边,每条边有一个甜蜜值,小$W$要选$K$条边,使得任意两点间最多有一条路径 ...
- 2015湖南省选集训DAY5——work(BZOJ4177)
Description Mike有一个农场,这个农场n个牲畜围栏,如今他想在每一个牲畜围栏中养一仅仅动物,每仅仅动物能够是牛或羊,并且每一个牲畜围栏中的饲养条件都不同,当中第i个牲畜围栏中的动物长大后 ...
- FJ省队集训DAY5 T1
思路:考试的时候打了LCT,自以为能过,没想到只能过80.. 考完一想:lct的做法点数是100W,就算是nlogn也会T. 讲一下lct的做法把:首先如果一条边连接的两个点都在同一个联通块内,那么这 ...
随机推荐
- cssfloat布局以及其他小技巧
css float 布局以及其他小技巧总结 这篇博文 前面四个部分是关于css 经典布局 如果你已经知道了 可以直接跳过看第六部分 css 的其他小技巧 1.0 左右居中布局 <!DOCTYPE ...
- DevExpress v19.1新版亮点——WinForms篇(五)
行业领先的.NET界面控件DevExpress v19.1终于正式发布,本站将以连载的形式介绍各版本新增内容.在本系列文章中将为大家介绍DevExpress WinForms v19.1中新增的一些控 ...
- thinkPHP模型定义
批量新增 ArrayAccess类的属性当做数组访问 插入语句 这段代码说明,User继承的Model类的isupdate属性默认是isupdate,而User::get(1)把这一字段属性更新为tr ...
- python之路day13--迭代器
迭代器 我们已经知道,可以直接作用于for循环的数据类型有以下几种: 一类是集合数据类型,如list.tuple.dict.set.str等: 一类是generator,包括生成器和带yield的ge ...
- 【NOIP2016提高A组模拟8.17】(雅礼联考day1)Matrix
题目 分析 假设,我们从\(F_{i,2}\)出发,那么对\(F_{n,n}\)的贡献就是\(某个系数乘以a^{n-i}b^{n-1}r_i\): 同理,如果从\(F_{2,i}\)出发,那么对\(F ...
- 算法复习-a 到 z不完全排列生成
在网上看到这个题,觉得很有意思,也算是一种方法...但是复杂度同样很高,生成全排列本身需要很大复杂度. 题目:现在有 a 到 z 26 个元素, 编写程序打印 a 到 z 中任取 3 个元素的组合(比 ...
- 【leetcode】1208. Get Equal Substrings Within Budget
题目如下: You are given two strings s and t of the same length. You want to change s to t. Changing the ...
- 虚拟机安装 Output error file to the following location
有的用户会对你中安装虚拟机系统,但偶尔会在安装过程中遇到一些问题.比如在电脑安装虚拟机系统时出现提示“Output error file to the following location”,这一般是 ...
- HDU 6191 Query on A Tree(字典树+离线)
Query on A Tree Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Othe ...
- C#获取网页信息并存入数据库
1,获取以及商品分类信息 给一网页获取网页上商品信息的分类 using Skay.WebBot; using System; using System.Collections.Generic; usi ...