题解:

没打。。。

ab题满世界都过了应该没什么意思

c题是个比较有意思的思维题(先看了题解才会的。。。)

我们考虑这么一件事情

没钥匙的人出门后

门一定是开着的

他进来的时候,门一定是开着的

其他时候,一定门能关着比较好

但是这个东西并不是很好维护,因为可能重复算

我们考虑重新排个序

我们把a[]在b[]前面的那个排在他前面

这样我们只需要记录一下上一个取了没有就可以了

感觉说出来不是很好理解这个东西。。。

d题还是个有点难度的数据结构题

一件比较显然的事情是我们对a的操作等价于是要

找当前x修改后是不是前缀最大值,以及他能延伸到哪(这个权值线段树显然可以维护)

然后就变成了区间覆盖成一个值了

然后 刚开始就想错了。。。

刚开始想的是去考虑这一段的值是怎么通过原先值变化的

其实这样反而不好做

直接去暴力统计现在的值

那么我们要知道的其实就是 当前区间>k的数的个数以及<k的数的乘积

这玩意我好像只会树套树或者cdq分治+排序+线段树。。。(写起来挺烦的啊)

于是复杂度就是nlog^2n了

不知道正解是怎么玩的。。。

代码:

c:

#include <bits/stdc++.h>
using namespace std;
#define rint register int
#define IL inline
#define rep(i,h,t) for (rint i=h;i<=t;i++)
#define dep(i,t,h) for (rint i=t;i>=h;i--)
const int N=;
const int INF=1e9;
struct re{
int a,b,c,pos;
}a[N],b[N],c1[N],c2[N],p[N];
int pre[N],pos[N],x1[N],x2[N],f[N][N][];
bool tt[N];
bool cmp(re x,re y)
{
return x.b<y.b;
}
int main()
{
freopen("1.in","r",stdin);
freopen("1.out","w",stdout);
ios::sync_with_stdio(false);
int n,m;
cin>>n>>m;
rep(i,,n)
{
cin>>a[i].a>>a[i].b; a[i].pos=i;
b[i*-].a=i*-; b[i*-].b=a[i].a;
b[i*].a=i*; b[i*].b=a[i].b;
}
sort(a+,a+n+,cmp);
sort(b+,b+*n+,cmp);
rep(i,,n) pos[a[i].pos]=i;
rep(i,,n*)
{
if (b[i].a%==&&b[i-].a%==)
pre[b[i].a/]=(b[i-].a+)/;
if (b[i].a%==) x2[b[i].a/]=b[i].b-b[i-].b;
if (b[i].a%==) x1[(b[i].a+)/]=b[i+].b-b[i].b;
}
int cnt=;
rep(i,,n)
if (!tt[i])
{
int x=i;
p[++cnt].a=a[x].a; p[cnt].b=a[x].b; p[cnt].c=; tt[i]=;
if (pos[pre[a[x].pos]]!=x)
c1[cnt].a=x1[a[x].pos],c1[cnt].b=x2[a[x].pos];
else
c1[cnt].a=x1[a[x].pos],c1[cnt].b=;
while (pos[pre[a[x].pos]]&&pos[pre[a[x].pos]]!=x)
{
x=pos[pre[a[x].pos]];
tt[x]=;
p[++cnt].a=a[x].a; p[cnt].b=a[x].b; p[cnt].c=;
c1[cnt].a=x1[a[x].pos]; c1[cnt].b=x2[a[x].pos];
}
}
rep(i,,n)
rep(j,,m)
{
f[i][j][]=f[i][j][]=INF;
if (p[i].c)
{
if (j) f[i][j][]=min(f[i][j][],min(f[i-][j-][],f[i-][j-][]));
f[i][j][]=min(f[i][j][],f[i-][j][]+c1[i].b);
f[i][j][]=min(f[i][j][],f[i-][j][]+c1[i].b+c1[i].a);
} else
{
if (j) f[i][j][]=min(f[i][j][],min(f[i-][j-][],f[i-][j-][]));
f[i][j][]=min(f[i][j][],f[i-][j][]+c1[i].b+c1[i].a);
f[i][j][]=min(f[i][j][],f[i-][j][]+c1[i].b+c1[i].a);
}
}
cout<<min(f[n][m][],f[n][m][]);
return ;
}

【LGR-052】洛谷9月月赛II(加赛)的更多相关文章

  1. 【LGR-054】洛谷10月月赛II

    [LGR-054]洛谷10月月赛II luogu 成功咕掉Codeforces Round #517的后果就是,我\(\mbox{T4}\)依旧没有写出来.\(\mbox{GG}\) . 浏览器 \( ...

  2. 洛谷10月月赛II题解

    [咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...

  3. 洛谷9月月赛II 赛后瞎写

    看错比赛时间了....结果发现的时候已经开始了半个小时,并且当时正准备睡午觉qwq 于是就水了个t1就 去睡 跑了 T2 写着写着然后看了一发评讲被辣鸡思路给绕了进去最后发现自己宛若一个智障 类似桶的 ...

  4. 洛谷 4933 洛谷10月月赛II T2 大师

    [题解] f[i][j]表示最后一个数为h[i],公差为j的等差数列的个数.n方枚举最后一个数和倒数第二个数转移即可.注意公差可能为负数,需要移动为正数再作为下标. #include<cstdi ...

  5. 洛谷 4932 洛谷10月月赛II T1 浏览器

    [题解] x xor y的结果在二进制下有奇数个1,等价于x与y在二进制下的1的个数之和为奇数,因为x xor y减少的1的个数一定是偶数(两个数这一位都为1,xor的结果为0,减少了2个1) 那么答 ...

  6. 洛谷10月月赛II

    #A: P4924 [1007]魔法少女小Scarlet 这道题考了矩阵旋转 其实很考验推公式的能力和代码能力 这里有个小技巧 可以设(x, y)为原点,然后去推公式,然后实际操作中横坐标加上x,纵坐 ...

  7. 【LGR-061】洛谷10月月赛 II & X Round 4 Div.1&Div 2

    X Round的题目质量还是一如既往的高 然而每次周末我都要写作业没法用心打233主要是被陈指导放了鸽子 占坑代填(最近坑开的有点多)

  8. 【CSGRound2】逐梦者的初心(洛谷11月月赛 II & CSG Round 2 T3)

    题目描述# 给你一个长度为\(n\)的字符串\(S\). 有\(m\)个操作,保证\(m≤n\). 你还有一个字符串\(T\),刚开始为空. 共有两种操作. 第一种操作: 在字符串\(T\)的末尾加上 ...

  9. [LGR-054]洛谷10月月赛II

    浏览器 结论popcnt(x^y)和popcnt(x)+popcnt(y)的奇偶性相同. 然后就是popcnt为奇数的乘为偶数的.预处理一下\(2^{16}\)次方以内的popcnt,直接\(O(1) ...

随机推荐

  1. SQL SERVER 常见SQL和函数使用

    一.语法 参考原文:https://blog.csdn.net/xushaozhang/article/details/55053037 1.查询插入 (1)SELECT INTO 语句格式: Ora ...

  2. 【转】判断处理器是Big_endian的还是Little_endian的

    首先说明一下Little_endian和Big_endian是怎么回事. Little_endian模式的CPU对操作数的存放方式是从低字节到高字节,而Big_endian模式则是从高字节到低字节,比 ...

  3. Alpha 冲刺 (6/10)

    目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:感恩节~ 团队部分 后敬甲(组长) 过去两天完成了哪些任务 文字描述 设计了拍照界面和图片上传界面 沟通了前端进度 接下 ...

  4. java interview

    gitbook address https://dongchuan.gitbooks.io/java-interview-question/content/java/==_equal.html

  5. elasticsearch5.0.1集群排错的几个思路总结

    1.首先查看集群整体健康状态 # curl -XGET http://10.27.35.94:9200/_cluster/health?pretty { "cluster_name" ...

  6. PHP IDE选择标准

    2017年11月17日09:35:01 这里记录一下PHP IDE的选择标准 1.  是否有错误提示, 对于一些 `缺少分号`, `花括号不配对`, `变量未定义就使用`等待的提示是要有的 2. 代码 ...

  7. MVC之基架

    参考 ASP.NET MVC5 高级编程(第5版) 定义: 通过对话框生成视图及控制器的模版,这个过程叫做“基架”. 基架可以为应用程序的创建.读取.更新和删除(CRUB)功能生成所需的样板代码.基架 ...

  8. MinGW-w64非官方编译器集成安装包(很清楚)

    官方链接[编辑] MinGW 官方网站. SourceForge.net上的MinGW官方的下载站点(Win32系统). MinGW-w64官方的下载站点[编辑] MinGW-w64是2005年由On ...

  9. bootstrap DataTable绑定数据带服务器分页

    <!-- DataTables -->  这两个文件在我的文件夹里面<script src="~/bower_components/datatables.net/js/jq ...

  10. 每天备份tomcat日志

    #!/bin/bash Backup_Home=/data/backup-log mkdir -p $Backup_Home Log_Home=/data/Tomcat/logs App_Log_Ho ...