20191004 「HZOJ NOIP2019 Round #9」20191004模拟
综述
第一次 rk1
,激动。
题目是 COCI 18/19 Round #1
的三至五题。
得分 \(100+100+20\)
\(\mathrm{cipele}\)
问题描述
题解
二分答案+贪心
发现“最大值最小”,自然想到二分答案。
对 \(a,b\) 排序,通过一些操作保证 \(a\) 比 \(b\) 短。
如果 \(b_j\) 不能被 \(a_i\) 选择,那么它一定不能被 \(a_k(k>i)\) 选择。
基于这个贪心配对即可。
\(\mathrm{Code}\)
#include<bits/stdc++.h>
using namespace std;
void read(int &x){
x=0;char ch=1;int fh;
while(ch!='-'&&(ch>'9'||ch<'0')) ch=getchar();
if(ch=='-') ch=getchar(),fh=-1;
else fh=1;
while(ch>='0'&&ch<='9') x=(x<<1)+(x<<3)+ch-'0',ch=getchar();
x*=fh;
}
const int maxn=100000+7;
const int INF=0x3f3f3f3f;
int n,m,mxa=-INF,mia=INF,mxb=-INF,mib=INF;
int a[maxn],b[maxn];
int l,r,mid,ans;
bool check(){
int j=1;bool eps;
for(int i=1;i<=n;i++){
eps=0;
for(;j<=m;j++){
if(abs(a[i]-b[j])<=mid){
++j;eps=1;break;
}
}
if(!eps) return false;
}
return true;
}
void deal(){
for(int i=1;i<=n;i++) swap(a[i],b[i]);
swap(n,m);
}
int main(){
freopen("cipele.in","r",stdin);freopen("cipele.out","w",stdout);
read(n);read(m);
for(int i=1;i<=n;i++) read(a[i]),mxa=max(mxa,a[i]),mia=min(mia,a[i]);
for(int i=1;i<=m;i++) read(b[i]),mxb=max(mxb,b[i]),mib=min(mib,b[i]);
if(n>m) deal();
sort(a+1,a+n+1);sort(b+1,b+m+1);
l=0,r=max(abs(mxa-mib),abs(mxb-mia));
while(l<=r){
mid=(l+r)>>1;
if(check()){
ans=mid;r=mid-1;
}
else l=mid+1;
}
printf("%d\n",ans);
return 0;
}
\(\mathrm{strah}\)
问题描述
题解
单调栈维护最大矩形
打表找规律
\(\mathrm{Code}\)
#include<bits/stdc++.h>
using namespace std;
#define int long long
void read(int &x){
x=0;char ch=1;int fh;
while(ch!='-'&&(ch>'9'||ch<'0')) ch=getchar();
if(ch=='-') ch=getchar(),fh=-1;
else fh=1;
while(ch>='0'&&ch<='9') x=(x<<1)+(x<<3)+ch-'0',ch=getchar();
x*=fh;
}
void fr(int &x){
char ch=1;
while(ch!='.'&&ch!='#') ch=getchar();
if(ch=='.') x=0;
else x=1;
}
const int maxn=2000+7;
int sta[maxn],top;
int n,m,a[maxn][maxn];
int lft[maxn],rgt[maxn];
int tmp[maxn];
int ans;
int solve(int j){
int a=j-lft[j]+1,b=rgt[j]-j+1;
return a*(a+1)/2*b+b*(b+1)/2*a-a*b;
}
signed main(){
freopen("strah.in","r",stdin);freopen("strah.out","w",stdout);
read(n);read(m);
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
fr(a[i][j]);
}
}
for(int i=1;i<=n;i++){
top=0;
for(int j=1;j<=m;j++){
if(!a[i][j]) tmp[j]++;
else tmp[j]=0;
while(top&&tmp[sta[top]]>tmp[j]){
rgt[sta[top]]=j-1;--top;
}
lft[j]=sta[top]+1;
sta[++top]=j;
}
while(top) rgt[sta[top--]]=m;
for(int j=1;j<=m;j++){
ans=ans+tmp[j]*(tmp[j]+1)*solve(j)/2;
}
}
printf("%lld\n",ans);
return 0;
}
\(\mathrm{teoreticar}\)
问题描述
题解
只会暴力
暴力染色,判断是否可行
这样貌似求出来的就是 \(C\) .
20191004 「HZOJ NOIP2019 Round #9」20191004模拟的更多相关文章
- 20191102 「HZOJ NOIP2019 Round #12」20191102模拟
先开坑. md原题写挂我也真是... 100+20+10 白夜 打表大法吼 显然,不在环上的点对答案的贡献是 \((k-cycle)^{k-1}\) . 打表得到环上的递推式,矩阵一下乘起来就好了. ...
- 20191003 「HZOJ NOIP2019 Round #8」20191003模拟
综述 试题为常州集训2019SCDay2 得分\(100+30(0)+28\) 时之终结 问题描述 HZOJ1310 题解 构造题. 发现部分分有一档是 \(Y\) 是 \(2^x\) ,于是自然想到 ...
- 20190922 「HZOJ NOIP2019 Round #7」20190922模拟
综述 这次是USACO2019JAN Gold的题目. \(\mathrm{Cow Poetry}\) 题解 因为每句诗的长度一定是\(k\),所以自然而然想到背包. 设\(opt[i][j]\)代表 ...
- 「LibreOJ NOI Round #2」不等关系
「LibreOJ NOI Round #2」不等关系 解题思路 令 \(F(k)\) 为恰好有 \(k\) 个大于号不满足的答案,\(G(k)\) 表示钦点了 \(k\) 个大于号不满足,剩下随便填的 ...
- LibreOJ #507. 「LibreOJ NOI Round #1」接竹竿
二次联通门 : LibreOJ #507. 「LibreOJ NOI Round #1」接竹竿 /* LibreOJ #507. 「LibreOJ NOI Round #1」接竹竿 dp 记录一下前驱 ...
- 「LibreOJ NOIP Round #1」旅游路线
Description T 城是一个旅游城市,具有 nnn 个景点和 mmm 条道路,所有景点编号为 1,2,...,n1,2,...,n1,2,...,n.每条道路连接这 nnn 个景区中的某两个景 ...
- 「LibreOJ NOI Round #1」验题
麻烦的动态DP写了2天 简化题意:给树,求比给定独立集字典序大k的独立集是哪一个 主要思路: k排名都是类似二分的按位确定过程. 字典序比较本质是LCP下一位,故枚举LCP,看多出来了多少个独立集,然 ...
- #509. 「LibreOJ NOI Round #1」动态几何问题
下面给出部分分做法和满分做法 有一些奇妙的方法可以拿到同样多的分数,本蒟蒻只能介绍几种常见的做法 如果您想拿18分左右,需要了解:质因数分解 如果您想拿30分左右,需要了解:一种较快的筛法 如果您想拿 ...
- LibreOJ #539. 「LibreOJ NOIP Round #1」旅游路线(倍增+二分)
哎一开始看错题了啊T T...最近状态一直不对...最近很多傻逼题都不会写了T T 考虑距离较大肯定不能塞进状态...钱数<=n^2能够承受, 油量再塞就不行了...显然可以预处理出点i到j走c ...
随机推荐
- selenium如何向ueditor富文本中自动输入文本
1.网上给出的方法在百度的富文本控件ueditor中不起作用切换框架失败 2.利用ueditor的api文档,通过js不使用框架切换即可实现轻松写入 eg:ue.setContent('hello')
- python中copy()和deepcopy()详解
**首先直接上结论: —–我们寻常意义的复制就是深复制,即将被复制对象完全再复制一遍作为独立的新个体单独存在.所以改变原有被复制对象不会对已经复制出来的新对象产生影响.—–而浅复制并不会产生一个独立的 ...
- Java Web 学习(4) —— Spring MVC 概览
Spring MVC 概览 一. Spring MVC Spring MVC 是一个包含了 Dispatcher Servlet 的 MVC 框架. Dispatcher Servlet 实现了 : ...
- 第04组 Alpha冲刺(3/4)
队名:斗地组 组长博客:地址 作业博客:Alpha冲刺(3/4) 各组员情况 林涛(组长) 过去两天完成了哪些任务: 1.收集各个组员的进度 2.写博客 展示GitHub当日代码/文档签入记录: 接下 ...
- C#位运算实际作用之操作整型某一位
1.前言 前几天写了两篇关于c#位运算的文章 c#位运算基本概念与计算过程 C#位运算实际运用 在文中也提到了位运算的实际作用之一就是合并整型,当时引用了一个问题: C# 用两个short,一个int ...
- selenium爬取NBA并将数据存储到MongoDB
from selenium import webdriver driver = webdriver.Chrome() url = 'https://www.basketball-reference.c ...
- Groovy元编程简明教程
同函数式编程类似,元编程,看上去像一门独派武学. 在 <Ruby元编程>一书中,定义:元编程是运行时操作语言构件的编程能力.其中,语言构件指模块.类.方法.变量等.常用的主要是动态创建和访 ...
- 相关pycharm(进阶?)
记录今日发现 对于pycharm细节 注意:项目的位置可以自己定 这里的新建project,建议对python.exe 文件的选择使用自己安装的位置,如下图 create,你就有了一个解释器是你自己安 ...
- 现代C++实现多种print
目录 Print Version1 Print Version2 Print Version3 Print Version4 容器的Print tuple容器的print 结语 学习C++的朋友会遇到 ...
- 【洛谷2791】幼儿园篮球题(第二类斯特林数,NTT)
[洛谷2791]幼儿园篮球题(第二类斯特林数,NTT) 题面 洛谷 题解 对于每一组询问,要求的东西本质上就是: \[\sum_{i=0}^{k}{m\choose i}{n-m\choose k-i ...