综述

第一次 rk1 ,激动。

题目是 COCI 18/19 Round #1 的三至五题。

得分 \(100+100+20\)


\(\mathrm{cipele}\)

问题描述

HZOJ1313

题解

二分答案+贪心

发现“最大值最小”,自然想到二分答案。

对 \(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}\)

问题描述

HZOJ1314

题解

单调栈维护最大矩形

打表找规律

\(\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}\)

问题描述

HZOJ1315

题解

只会暴力

暴力染色,判断是否可行

这样貌似求出来的就是 \(C\) .

20191004 「HZOJ NOIP2019 Round #9」20191004模拟的更多相关文章

  1. 20191102 「HZOJ NOIP2019 Round #12」20191102模拟

    先开坑. md原题写挂我也真是... 100+20+10 白夜 打表大法吼 显然,不在环上的点对答案的贡献是 \((k-cycle)^{k-1}\) . 打表得到环上的递推式,矩阵一下乘起来就好了. ...

  2. 20191003 「HZOJ NOIP2019 Round #8」20191003模拟

    综述 试题为常州集训2019SCDay2 得分\(100+30(0)+28\) 时之终结 问题描述 HZOJ1310 题解 构造题. 发现部分分有一档是 \(Y\) 是 \(2^x\) ,于是自然想到 ...

  3. 20190922 「HZOJ NOIP2019 Round #7」20190922模拟

    综述 这次是USACO2019JAN Gold的题目. \(\mathrm{Cow Poetry}\) 题解 因为每句诗的长度一定是\(k\),所以自然而然想到背包. 设\(opt[i][j]\)代表 ...

  4. 「LibreOJ NOI Round #2」不等关系

    「LibreOJ NOI Round #2」不等关系 解题思路 令 \(F(k)\) 为恰好有 \(k\) 个大于号不满足的答案,\(G(k)\) 表示钦点了 \(k\) 个大于号不满足,剩下随便填的 ...

  5. LibreOJ #507. 「LibreOJ NOI Round #1」接竹竿

    二次联通门 : LibreOJ #507. 「LibreOJ NOI Round #1」接竹竿 /* LibreOJ #507. 「LibreOJ NOI Round #1」接竹竿 dp 记录一下前驱 ...

  6. 「LibreOJ NOIP Round #1」旅游路线

    Description T 城是一个旅游城市,具有 nnn 个景点和 mmm 条道路,所有景点编号为 1,2,...,n1,2,...,n1,2,...,n.每条道路连接这 nnn 个景区中的某两个景 ...

  7. 「LibreOJ NOI Round #1」验题

    麻烦的动态DP写了2天 简化题意:给树,求比给定独立集字典序大k的独立集是哪一个 主要思路: k排名都是类似二分的按位确定过程. 字典序比较本质是LCP下一位,故枚举LCP,看多出来了多少个独立集,然 ...

  8. #509. 「LibreOJ NOI Round #1」动态几何问题

    下面给出部分分做法和满分做法 有一些奇妙的方法可以拿到同样多的分数,本蒟蒻只能介绍几种常见的做法 如果您想拿18分左右,需要了解:质因数分解 如果您想拿30分左右,需要了解:一种较快的筛法 如果您想拿 ...

  9. LibreOJ #539. 「LibreOJ NOIP Round #1」旅游路线(倍增+二分)

    哎一开始看错题了啊T T...最近状态一直不对...最近很多傻逼题都不会写了T T 考虑距离较大肯定不能塞进状态...钱数<=n^2能够承受, 油量再塞就不行了...显然可以预处理出点i到j走c ...

随机推荐

  1. ES6 class类中定义私有变量

    ES6 class类中定义私有变量 class类的不足 看起来, es6 中 class 的出现拉近了 JS 和传统 OOP 语言的距离.但是,它仅仅是一个语法糖罢了,不能实现传统 OOP 语言一样的 ...

  2. 给那些迷茫的人学习JAVA的一些建议?

    前语:我用了3年的时间,一步一步走到了现在,半途也有了解过其他的技能,也想过要转其他的言语,可是最终仍是坚持下来走Java这条路,希望我的经历能够帮忙到后来的人,要是觉得对你有帮忙的话,能够注重一下和 ...

  3. AtCoder Grand Contest 040

    Preface 今年准备省选啥都不说了,省选题基本上都做过一遍了,开始尝试板刷AGC 这场做完就从AGC001开始吧,感觉以我的速度和来机房的频率一个礼拜做一场都谢天谢地了 A - >< ...

  4. 1+X证书web前端开发中级对应课程分析

    官方QQ群 1+x 证书 Web 前端开发 JavaScript 专项练习 http://blog.zh66.club/index.php/archives/198/ 1+x 证书 Web 前端开发初 ...

  5. 【2016NOI十连赛2-2】黑暗

    [2016NOI十连赛2-2]黑暗 题目大意:定义一个无向图的权值为连通块个数的\(m\)次方.求\(n\)个点的所有无向图的权值和.多次询问. 数据范围:\(T\leq 1000,n\leq 300 ...

  6. 易飞ERP API接口调用DEMO

    一.使用场景: 1.需要开放ERP数据给第三方系统对接,如APP手机端开发,MES,OA等: 2.接口按现在主流开发,restful风格,传JSON数据,跨平台,不限开发工具: 3.不限易飞ERP,支 ...

  7. d03

    回顾: 两个环境 工具环境:Jmeter的下载.启动.基本使用 项目环境:学生信息管理系统 两种接口: 天气预报:4个接口----GET方法 学生信息管理系统: 被测软件的学院信息接口: 4类: 查询 ...

  8. Java开发桌面程序学习(13)——Javafx多线程 下载功能

    普通使用 Task<Void> task = new Task<Void>() { @Override protected void succeeded() { super.s ...

  9. python基础(20):序列化、json模块、pickle模块

    1. 序列化 什么叫序列化——将原本的字典.列表等内容转换成一个字符串的过程就叫做序列化. 1.1 为什么要有序列化 为什么要把其他数据类型转换成字符串?因为能够在网络上传输的只能是bytes,而能够 ...

  10. Java日期时间API系列4-----Jdk7及以前的日期时间类的线程安全问题

    1.Date类为可变的,在多线程并发环境中会有线程安全问题. (1)可以使用锁来处理并发问题. (2)使用JDK8  Instant 或 LocalDateTime替代. 2.Calendar的子类为 ...