【LGR-052】洛谷9月月赛II(加赛)
题解:
没打。。。
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(加赛)的更多相关文章
- 【LGR-054】洛谷10月月赛II
[LGR-054]洛谷10月月赛II luogu 成功咕掉Codeforces Round #517的后果就是,我\(\mbox{T4}\)依旧没有写出来.\(\mbox{GG}\) . 浏览器 \( ...
- 洛谷10月月赛II题解
[咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...
- 洛谷9月月赛II 赛后瞎写
看错比赛时间了....结果发现的时候已经开始了半个小时,并且当时正准备睡午觉qwq 于是就水了个t1就 去睡 跑了 T2 写着写着然后看了一发评讲被辣鸡思路给绕了进去最后发现自己宛若一个智障 类似桶的 ...
- 洛谷 4933 洛谷10月月赛II T2 大师
[题解] f[i][j]表示最后一个数为h[i],公差为j的等差数列的个数.n方枚举最后一个数和倒数第二个数转移即可.注意公差可能为负数,需要移动为正数再作为下标. #include<cstdi ...
- 洛谷 4932 洛谷10月月赛II T1 浏览器
[题解] x xor y的结果在二进制下有奇数个1,等价于x与y在二进制下的1的个数之和为奇数,因为x xor y减少的1的个数一定是偶数(两个数这一位都为1,xor的结果为0,减少了2个1) 那么答 ...
- 洛谷10月月赛II
#A: P4924 [1007]魔法少女小Scarlet 这道题考了矩阵旋转 其实很考验推公式的能力和代码能力 这里有个小技巧 可以设(x, y)为原点,然后去推公式,然后实际操作中横坐标加上x,纵坐 ...
- 【LGR-061】洛谷10月月赛 II & X Round 4 Div.1&Div 2
X Round的题目质量还是一如既往的高 然而每次周末我都要写作业没法用心打233主要是被陈指导放了鸽子 占坑代填(最近坑开的有点多)
- 【CSGRound2】逐梦者的初心(洛谷11月月赛 II & CSG Round 2 T3)
题目描述# 给你一个长度为\(n\)的字符串\(S\). 有\(m\)个操作,保证\(m≤n\). 你还有一个字符串\(T\),刚开始为空. 共有两种操作. 第一种操作: 在字符串\(T\)的末尾加上 ...
- [LGR-054]洛谷10月月赛II
浏览器 结论popcnt(x^y)和popcnt(x)+popcnt(y)的奇偶性相同. 然后就是popcnt为奇数的乘为偶数的.预处理一下\(2^{16}\)次方以内的popcnt,直接\(O(1) ...
随机推荐
- python3+selenium入门12-警告框处理
在WebDriver中要处理JS生成的alert.confirm以及prompt,需要使用到switch_to_alert()定位到alert/confirm/prompt,然后再使用text.acc ...
- 使用openssl命令制作ecc证书
# openssl ecparam -out EccCA.key -name prime256v1 -genkey # openssl req -config openssl.cnf -key Ecc ...
- matlab常用命令
clc; %清屏 clear; %清除变量 close all; %关闭 doc %查看文档 meshgrid%采样mesh %网格曲面surf %光滑曲面plot %ezplotdiff figur ...
- lanmp安装
下载安装(ssh登录服务器,执行如下操作即可,需要用到root用户权限来安装)源码编译安装wget http://dl.wdlinux.cn:5180/lanmp_laster.tar.gztar z ...
- ASP.NET Core之NLog使用
1.新建ASP.NET Core项目 1.1选择项目 1.2选择.Net版本 2. 添加NLog插件 2.1 通过Nuget安装 2.2下载相关的插件 3.修改NLog配置文件 3.1添加NLog配置 ...
- Selenium+Java自动化之如何优雅绕过验证码
前言: 验证码问题对于每个ui自动化的同学而言,相信都是个蛋疼的问题,对于验证码的处理我个人不提倡破解,不要去想破解方法,这个验证码本来就是为了防止别人自动化登录的.如果你们公司的验证码很容易被你破解 ...
- 定制起始url(scrapy_redis)
爬虫:(在这里不用配置start_url,直接可以取redis里面取start_url,可以多个) from scrapy_redis.spiders import RedisSpider # cla ...
- 缺失dll的问题
不小心运行一下什么程序就会出现缺失xxx.dll的问题,太烦了,遇到好多,一直没有记录.现在开始记录,以便日后查看~ 1. api-ms-win-crt-runtime-l1-1-0.dll 64位系 ...
- Json数据和对象互转
1.创建UserTest类 package com.cppdy; public class UserTest { private String name; private String sex; pu ...
- 第二十单元 计划任务crond服务
什么是计划任务:后台运行,到了预定的时间就会自动执行的任务,前提是:事先手动将计划任务设定好.这就用到了crond服务 crond服务相关的软件包[root@MiWiFi-R3-srv ~]# rpm ...