2017 清北济南考前刷题Day 6 morning
T1
贪心
10 元先找5元
20元 先找10+5,再找3张5
#include<cstdio> using namespace std; int m5,m10,m20; int main()
{
freopen("book.in","r",stdin);
freopen("book.out","w",stdout);
int n;
scanf("%d",&n);
int x;
for(int i=;i<=n;i++)
{
scanf("%d",&x);
if(x==) m5++;
else if(x==)
{
if(!m5) { puts("NO"); return ; }
m5--; m10++;
}
else
{
if(m10 && m5) m10--,m5--;
else if(m5>=) m5-=;
else { puts("NO"); return ; }
}
}
puts("YES"); return ;
}
T2
小c记得的出口位置看做左括号
从右往左扫描 信息
左括号入栈
否则判断当前栈顶 是否能匹配,
匹配则为右括号,不匹配当左括号入栈
栈空则有解,非空则无解
#include<cstdio>
#include<iostream>
#include<algorithm> #define N 1000001 using namespace std; int a[N]; int st[N],top; bool zf[N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} int main()
{
freopen("program.in","r",stdin);
freopen("program.out","w",stdout);
int n,m;
read(n);
for(int i=;i<=n;++i) read(a[i]);
read(m);
int x;
for(int i=;i<=m;++i)
{
read(x);
if(a[x]>) a[x]=-a[x];
}
for(int i=n;i;--i)
{
if(a[i]<) st[++top]=a[i],zf[i]=true;
else
{
if(st[top]==-a[i]) top--;
else st[++top]=-a[i],zf[i]=true;
}
}
if(top) { puts("NO"); return ; }
for(int i=;i<=n;i++)
{
if(!zf[i]) printf("+%d ",abs(a[i]));
else printf("-%d ",abs(a[i]));
}
fclose(stdin); fclose(stdout);
return ;
}
不会spj所以不知道对错的代码
对于一个出口,判断前面是否有足够的入口
#include<cstdio>
#include<iostream>
#include<algorithm> using namespace std; #define N 1000001 int a[N],b[N];
int tot[N],pre[N]; int outtot[N]; bool out[N],zf[N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} int main()
{
freopen("program.in","r",stdin);
freopen("program.out","w",stdout);
int n; read(n);
int x;
for(int i=;i<=n;i++)
{
read(x); a[i]=x;
pre[i]=++tot[x];
}
int m; read(m);
for(int i=;i<=m;++i) read(b[i]);
sort(b+,b+m+);
int t=unique(b+,b+m+)-b-;
for(int i=;i<=t;i++)
{
x=b[i];
outtot[a[x]]++; out[x]=true;
if(pre[x]<outtot[a[x]]*) { puts("NO"); return ; }
}
for(int i=;i<=n;i++)
if(tot[i]&) { puts("NO"); return ; }
for(int i=;i<=n;i++)
{
if(out[i]) printf("-%d ",a[i]);
else if(outtot[a[i]]) printf("+%d ",a[i]),outtot[a[i]]--;
else if(!zf[a[i]]) printf("+%d ",a[i]),zf[a[i]]^=;
else printf("-%d ",a[i]),zf[a[i]]^=;
}
}
T3
把钥匙看做左括号,门看做右括号
模拟括号匹配,任意两点间只有两种状态:匹配,缺右括号
那么问题转化为 从a走到b 能否括号匹配
宽搜+DP
dp[i][j][k]表示 点i到点j 是否有状态k
k=0 表示 i到j的路径上能够括号匹配
k:1——10 表示 点i到j的路径上,栈顶为右括号k
k:11——20 表示点i到j的路径上,栈顶为左括号k,即缺右括号k
每次更新一个ijk,就相当于在ij之间连一条状态为k的边,扔进队列里
从队列里取出 从u到v的状态为w的边
如果w=0,那么 枚举状态k (0,11——20)
if dp[i][u][k]=true 更新 dp[i][v][k]
if dp[v][i][k]=true 更新 dp[u][i][k]
如果w!=0,那么 只能去找右括号
即if dp[v][i][w-10] 更新 dp[u][i][0]
为什么 w=0 是双向更新,w!=0是单项更新?
因为只能是栈中有左括号的情况下,右括号才能入栈
对于每一次询问,判断dp[u][v][0] 即可
#include<cstdio> using namespace std; bool dp[][][]; int head,tail; int q[][]; int main()
{
freopen("maze.in","r",stdin);
freopen("maze.out","w",stdout);
int n,m;
scanf("%d%d",&n,&m);
for(int i=;i<=n;++i) dp[i][i][]=true;
int u,v,w;
while(m--)
{
scanf("%d%d%d",&u,&v,&w);
if(!w)
{
dp[u][v][w]=dp[v][u][w]=true;
q[tail][]=u; q[tail][]=v; q[tail++][]=w;
q[tail][]=v; q[tail][]=u; q[tail++][]=w;
}
else if(w<)
{
w=-w;
dp[u][v][w]=dp[v][u][w]=true;
}
else
{
w+=;
dp[u][v][w]=dp[v][u][w]=true;
q[tail][]=u; q[tail][]=v; q[tail++][]=w;
q[tail][]=v; q[tail][]=u; q[tail++][]=w;
}
}
while(head<tail)
{
u=q[head][]; v=q[head][]; w=q[head++][];
if(!w)
{
for(int i=;i<=n;++i)
{
if(dp[i][u][] && !dp[i][v][])
{
dp[i][v][]=true;
q[tail][]=i; q[tail][]=v; q[tail++][]=;
}
if(dp[v][i][] && !dp[u][i][])
{
dp[u][i][]=true;
q[tail][]=u; q[tail][]=i; q[tail++][]=;
}
for(int j=;j<=;++j)
{
if(dp[i][u][j] && !dp[i][v][j])
{
dp[i][v][j]=true;
q[tail][]=i; q[tail][]=v; q[tail++][]=j;
}
}
}
}
else
{
for(int i=;i<=n;++i)
{
if(dp[v][i][w-] && !dp[u][i][])
{
dp[u][i][]=true;
q[tail][]=u; q[tail][]=i; q[tail++][]=;
}
}
}
}
int q;
scanf("%d",&q);
while(q--)
{
scanf("%d%d",&u,&v);
puts(dp[u][v][] ? "YES" : "NO");
}
}
2017 清北济南考前刷题Day 6 morning的更多相关文章
- 2017 清北济南考前刷题Day 7 afternoon
期望得分:100+100+30=230 实际得分:100+100+30=230 1. 三向城 题目描述 三向城是一个巨大的城市,之所以叫这个名字,是因为城市中遍布着数不尽的三岔路口.(来自取名力为0的 ...
- 2017 清北济南考前刷题Day 1 afternoon
期望得分:80+30+70=180 实际得分:10+30+70=110 T1 水题(water) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK出了道水 ...
- 2017 清北济南考前刷题Day 3 morning
实际得分:100+0+0=100 T1 右上角是必败态,然后推下去 发现同行全是必胜态或全是必败态,不同行必胜必败交叉 列同行 所以n,m 只要有一个是偶数,先手必胜 #include<cstd ...
- 2017 清北济南考前刷题Day 3 afternoon
期望得分:100+40+100=240 实际得分:100+40+100=240 将每个联通块的贡献乘起来就是答案 如果一个联通块的边数>点数 ,那么无解 如果边数=点数,那么贡献是 2 如果边数 ...
- 2017 清北济南考前刷题Day 4 afternoon
期望得分:30+50+30=110 实际得分:40+0+0=40 并查集合并再次写炸... 模拟更相减损术的过程 更相减损术,差一定比被减数小,当被减数=减数时,停止 对于同一个减数来说,会被减 第1 ...
- 2017 清北济南考前刷题Day 7 morning
期望得分:100+50+20=170 实际得分:10+50+20=80 1. 纸牌 题目描述 在桌面上放着n张纸牌,每张纸牌有两面,每面都写着一个非负整数.你的邪王真眼可以看到所有牌朝上的一面和朝下的 ...
- 2017 清北济南考前刷题Day 6 afternoon
期望得分:100+100+30=230 实际得分: 正解: 枚举最高的位,这一位m是1但实际用了0 然后剩余的低位肯定是 正数就用1,负数用0 考场思路:数位DP #include<cstdio ...
- 2017 清北济南考前刷题Day 5 afternoon
期望得分:100+100+30=230 实际得分:0+0+0=30 T1 直接模拟 #include<cstdio> #include<iostream> using name ...
- 2017 清北济南考前刷题Day 5 morning
期望得分:100+100+0=200 实际得分: 坐标的每一位不是0就是1,所以答案就是 C(n,k) #include<cstdio> #include<iostream> ...
随机推荐
- 调研ANDRIOD平台的开发环境的发展演变
在同学的推荐下,我选用学习eclipse这个软件,参考了这个网址的教程开始了一步一步的搭建之路. http://jingyan.baidu.com/article/bea41d437a41b6b4c5 ...
- [2017BUAA软工]第3次个人作业
软工第3次个人作业--案例分析 一. 调研,评测 1.软件的bug(至少两个,不少于40字) 测试软件: 必应词典移动端 测试平台:iPhone 6 bug1 对于翻译功能中的图片翻译功能,必应词典是 ...
- Python入门:字符串的分片与索引、字符串的方法
这是关于Python的第3篇文章,主要介绍下字符串的分片与索引.字符串的方法. 字符串的分片与索引: 字符串可以用过string[X]来分片与索引.分片,简言之,就是从字符串总拿出一部分,储存在另一个 ...
- sql server数据库中raiserror函数的用法
server数据库中raiserror的作用就和asp.NET中的throw new Exception一样,用于抛出一个异常或错误.这个错误可以被程序捕捉到. raiserror的常用格式如下:ra ...
- 【Python】Python简介
Python是一种既使用简单又功能强大的高级编程语言,同时支持面向过程的编程和面向对象的编程. 官方对python的介绍:Python 是一种简单易学,功能强大的编程语言,它有高效率的高层数据结构,简 ...
- GIT的使用方法
GIT的使用方法 1.电脑首先安装GIT, 2.在官网注册GitHub账号. 一,使用git在控制台进行本地操作 1.打开GitBash 2.填写用户名和邮箱作为标识分别执行以下命令: git/ co ...
- Luogu 3385 负环 | 我有特别的SPFA技巧
这样似乎跑得快: 初始化所有的dis是0,然后枚举每个点作为起点,用DFS更新所有点的dis: 如果更新到一个栈中节点,那么有负环. #include <cstdio> #include ...
- 案例:Redis在京东的使用技术模型图
http://www.100ec.cn 2013年09月27日17:30 中国电子商务研究中心 我要投稿 产品服务 (中国电子商务研究中心讯)Redis是一个开源的,遵守BSD许可协议的key ...
- 解题:APIO 2014 序列分割
题面 拆开式子我们发现切割顺序不影响答案,所以可以设计出一个$dp[i][j]$表示到$i$为止切了$j$刀的最大收益之类的,然后做个前缀和就可以转移了. $dp[i][j]=min(dp[i][j] ...
- 2018.9.20 Educational Codeforces Round 51
蒟蒻就切了四道水题,然后EF看着可写然而并不会,中间还WA了一次,我太菜了.jpg =.= A.Vasya And Password 一开始看着有点虚没敢立刻写,后来写完第二题发现可以暴力讨论,因为保 ...