10-04 NOIP模拟赛
10-04 NOIP模拟赛
喜提80+30+10=120分
T1 水管(flow)
题目描述
某国有 \(n\) 个城市,水利调配非常有问题,这导致部分地区出现严重的缺水,而部分地区却全年洪灾泛滥。政府请你来做些调整和规划。
你打算将原有的但是已经废弃了的 \(m\) 条水管重新使用。第 \(i\) 条水管连接城市 \(x_i\) 和 \(y_i\) 。
这些水管联通了所有城市。每座城市对水的需求不同设为 \(a_i\),部分城市处于缺水状态,\(a_i\) 为正,部分城市处于洪涝状态,\(a_i\) 为负。
你需要做到每个城市都刚好满足它的需求,即缺 \(a_i\) mol 水的城市需要刚好输入 \(a_i\) 的水,而多出 \(a_i\) mol 水的城市需要刚好输出 \(a_i\) mol 水。
你需要判断能否满足要求,若满足,你还需要输出所有的 \(f\)
输出格式
如果不能满足要求,输出Impossible 。
如果满足要求,第一行输出Possible,接下来 \(m\) 行,第 \(i+1\) 行输出 \(f_i\)。
若有多组解,随意输出一组即可。 如果 \(f_i\)为0也要输出。
这道题乍一看跟网络流好像有亿点点关系,但是实则毛线关系没有。
首先一眼看出什么时候是 Impossible,即 \(a_i\) 的和为 0 时才可能每个城市刚好满足他的需求,你有15了
对于满足的情况有两种方法:归一法和推流法(自己取得名字)
法一:推流法
从树根开始 dfs,你可以理解为我手中推着节点里多余的谁向前走(当然可能是负的),我走过的节点都满足需求,因为和为0,所以我走完后手上剩下的水也为0。但是这种方法略显麻烦,因为我回溯的时候也要推着水走,太不方便了。
法二:归一法
如其名,这种方法即我先遍历到叶子结点,然后回溯的时候把水全部输到根节点综合一下就行了,简单好用。
开始80分是判Impossible的时候挂了。
AC 代码:
#include<bits/stdc++.h>
using namespace std;
#define N 1200000
typedef long long LL;
int nex[N],fir[N],to[N],vis[N],ret[N],w[N],tot=0;
int n,m,dian[N>>2];
bool ward[N];
void add(int x,int y,int flag,int rt){
nex[++tot]=fir[x];
fir[x]=tot;
to[tot]=y;
ward[tot]=flag;
ret[tot]=rt;
}
LL dfs(int u,int fa){//采用归一法
vis[u]=1;
int cnt=-dian[u];
for(int e=fir[u];e;e=nex[e]){
int v=to[e];
if(v==fa||vis[v]) continue;
int liu=dfs(v,u);
cnt+=liu;
if(ward[e]==1){
w[ret[e]]=-liu;
}
else w[ret[e]]=liu;
}
return cnt;
}
int main(){
freopen("flow.in","r",stdin);
freopen("flow.out","w",stdout);
scanf("%d",&n);
LL sum=0;
for(int i=1;i<=n;i++){
scanf("%d",&dian[i]);
sum+=dian[i];
}
if(sum){printf("Impossible\n");return 0;}
scanf("%d",&m);
for(int i=1;i<=m;i++){
int x,y;
scanf("%d%d",&x,&y);
add(x,y,1,i);
add(y,x,0,i);
}
printf("Possible\n");
int hai=dfs(1,0);
for(int i=1;i<=m;i++){
printf("%d\n",w[i]);
}
return 0;
}
备注:题解也用的这种方法。
T2 宝藏(treasure)
potato 游山涉水, 想要找到埋藏在深林中的宝藏。
他偶然得到了这个深林的藏宝图, 深林可以被看作一个 \(n * m\) 的矩阵。宝藏在地图中以 " $ $ $ "被标记出来,与此同时其他地方都是". "。
深林中有两条大河, 一条是纵向的, 一条是横向的。由于陆地上的宝藏都已经被人们 开采完了,potato 只好转而寻求埋藏在两条大河深处的宝藏。可他并不知道大河具体在哪,也不知道大河的宽度有多少,地图上也没有标明。他唯一确定的,是两条大河横跨整个深林。
他通过小道消息得出两条大河中的宝藏的个数之和为 \(\mathrm{k}\) 。请你帮 potato 统计 大河位置情况 的方案数。

如图是两条大河的合法位置, 注意大河方向一个为横,一个为纵,且长度都是无穷大的,宽度至少为 1。蓝色和黄色分别表示了两条大河,注意它们相交的绿色区域被计算了两次贡献。
对于 \(100 \%\) 的数据 \(\mathrm{n}, \mathrm{t}, \mathrm{k}<=100000, \mathrm{~m}<=100\) 提示: 请注意程序的常数和空间
首先拿到这道题的时候思路是很明显的:
因为重叠部分不冲突,所以我们把行和列分开来算,考虑到m只有100,所以果断预处理每行每列的宝藏数,然后求前缀和。存在map里,然后暴力从1枚举到k,求行和列的答案数和,赛时就是这样写的,于是收货了30分。
我们只允许在时间复杂度中出现n,而不是 \(n^2\)。所以思考从m入手,列产生的方案最多有 \(m^2\) 种,对于每一种合法的 \(k'\),我们考虑使用尺取法在n中通过滑动区间的方式找出所有的 \(k-k'\)。
尺取法
顺便对尺取法又有了更深的理解,以往对尺取法的理解仅限于双指针模拟一个滑动区间,但是这对于目标为0的区间会出现bug,特别是一串0,而且因为有0,也会导致含有0的部分值在一个区间内值相同。
对于这种问题,先做一个前缀和,我们可以每次采用一个类似三指针的方法,即一个一个枚举右端点,然后建立两个指针,一个枚举到大于目标答案,一个枚举到大于等于目标答案,差即使答案。
for(int i=1;i<=n;i++){
while(row[i]-row[lst-1]>K&&lst<=i)++lst;
while(row[i]-row[j-1]>=K&&j<=i)++j;
res+=j-lst;
}
然后你发现其实查找过程可以用二分代替,只是多个 \(log\),doge
AC 代码:
#include<bits/stdc++.h>
using namespace std;
#define N 200000
int ha[N],li[200];
int n,m,k;
long long ans=0;
map<int,int>mp1;
int main(){
freopen("treasure.in","r",stdin);
freopen("treasure.out","w",stdout);
scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=n;i++){
char ch[200];
scanf("%s",ch+1);
for(int j=1;j<=m;j++){
if(ch[j]=='$'){
ha[i]++;
li[j]++;
}
}
ha[i]+=ha[i-1];
}
for(int i=2;i<=m;i++){
li[i]+=li[i-1];
}
for(int len=1;len<=m;len++){
for(int i=len;i<=m;i++){
mp1[li[i]-li[i-len]]++;
}
}
for(auto v:mp1){
int kk=k-v.first;
long long sum=0;
for(int i=1;i<=n;i++){
sum+=upper_bound(ha,ha+i,ha[i]-kk)-lower_bound(ha,ha+i,ha[i]-kk);
}
ans+=sum*v.second;
}
printf("%lld",ans);
return 0;
}
顺便学习了map的遍历,大大的好!
10-04 NOIP模拟赛的更多相关文章
- 10.17 NOIP模拟赛
目录 2018.10.17 NOIP模拟赛 A 咒语curse B 神光light(二分 DP) C 迷宫maze(次短路) 考试代码 B 2018.10.17 NOIP模拟赛 时间:1h15min( ...
- 10.16 NOIP模拟赛
目录 2018.10.16 NOIP模拟赛 A 购物shop B 期望exp(DP 期望 按位计算) C 魔法迷宫maze(状压 暴力) 考试代码 C 2018.10.16 NOIP模拟赛 时间:2h ...
- 2018.10.16 NOIP模拟赛解题报告
心路历程 预计得分:\(100 + 100 + 20 = 220\) 实际得分:\(100 + 100 + 30 = 230\) 辣鸡模拟赛.. T1T2都是一眼题,T3考验卡常数还只有一档暴力分. ...
- 2016.10.30 NOIP模拟赛 day2 PM 整理
满分:300分 直接全部爆零,真的是很坑啊! 10.30的题目+数据:链接:http://pan.baidu.com/s/1jHXLace 密码:i784 T1: 题目中的难点就是每次折叠的点可能应经 ...
- 2016.10.30 NOIP模拟赛 day2 AM 整理
题目+数据:链接:http://pan.baidu.com/s/1gfBg4h1 密码:ho7o 总共得了:130分, 1:100分 2:30分(只会这30分的暴力) 3:0(毫无思路) 虽然不高, ...
- 2018.10.04 NOIP模拟 K进制(模拟)
传送门 签到题,直接瞎模拟就行了. 代码
- 2017 10.25 NOIP模拟赛
期望得分:100+40+100=240 实际得分:50+40+20=110 T1 start取了min没有用,w(゚Д゚)w O(≧口≦)O T3 代码3个bug :数组开小了,一个细节没注意, ...
- 2018.10.03 NOIP+ 模拟赛 解题报告
得分: \(30+5+0=35\)(考得真不咋滴) \(T1\):奥义商店(点此看题面) 以为很简单,对着这题想了一个多小时,最后果断打了个暴力交了... ... 看完题解发现其实也不是很难. 对于\ ...
- 2018.10.30 NOIp模拟赛 T1 改造二叉树
[题目描述] 小Y在学树论时看到了有关二叉树的介绍:在计算机科学中,二叉树是每个结点最多有两个子结点的有序树.通常子结点被称作“左孩子”和“右孩子”.二叉树被用作二叉搜索树和二叉堆.随后他又和他人讨论 ...
- 2016.10.29 NOIP模拟赛 PM 考试整理
300分的题,只得了第三题的100分. 题目+数据:链接:http://pan.baidu.com/s/1o7P4YXs 密码:4how T1:这道题目存在着诸多的问题: 1.开始的序列是无法消除的( ...
随机推荐
- 张高兴的 MicroPython 入门指南:(三)使用串口通信
目录 什么是串口 使用方法 使用板载串口相互通信 硬件需求 电路 代码 使用板载的 USB 串口 参考 什么是串口 串口是串行接口的简称,这是一个非常大的概念,在嵌入式中串口通常指 UART(Univ ...
- Aic 应用开发基础一(概念与场景)
Agi通用人工智能应用概念与场景 大家看到,自美国OpenAI主导的GPT发布以来,全球科技领域掀起了革命性的浪潮.比如最近看到的aigc 人工绘图,智能机器人等行业,很多新概念掘起, 随着人工智能技 ...
- DNS在架构中的使用
1 介绍 DNS(Domain Name System,域名系统)是一种服务,它是域名和IP地址相互映射的一个分布式数据库,能够使人更方便的访问互联网,而不用去记住能够被机器直接读取的IP地址数串. ...
- 7月24号python:库存管理
7月24号python:库存管理 题目: 仓库管理员以数组 stock 形式记录商品库存表.stock[i] 表示商品 id,可能存在重复.原库存表按商品 id 升序排列.现因突发情况需要进行商品 ...
- 鹏程实验室,启智平台,openI平台,积分兑换新标准
2024-02-13 11:12:21 星期二 地址: https://openi.pcl.ac.cn/reward/point/rule
- windows系统下安装gym运行atari游戏报错:ale_interface/ale_c.dll OSError
安装gym的atari支持: pip install gym[atari] 为gym下的atari环境下载游戏镜像ROMs文件: https://www.cnblogs.com/devilmayc ...
- 在vscode中通过修改launch.json文件为项目添加启动参数——在launch.json文件中修改args变量
以前一直在使用pycharm,不管怎么说毕竟国内外的Python编程者大部分都更支持pycharm,并且认为pycharm是Python语言编程中最好用的编辑器,但是随着国内编程人员一茬一茬的兴起很多 ...
- centos 7 安装 flask
最近 Python 特别火,尤其是在人工智能和大数据分析方面,更是如火如荼.正好放假有空就简单看了下Python 先从熟悉的地方入手,那就从web框架开始学学吧. 首先,官方给了安装方法:http:/ ...
- [学习笔记] 丢番图方程 & 同余 & 逆元 - 数论
首先,他们几个有着极大的相似性.另外,他们的各自的思想都能够很好的服务于另外几个,有助于加深理解. 文中有些letax公式抽风了,全屏之后应该能看得见-- 线性丢番图方程 丢番图不是个图啊!他是个ma ...
- GPL前世今生
从事Linux开发的朋友一定都听过GPL,那么到底什么是GPL呢?他有什么作用呢?本文给大家做详细讲解. 一.GNU/GPL 在讲解GPL之前,我们必须先了解什么是GNU? 1. 什么是GNU GNU ...