Nowcoder 提高组练习赛-R7
Nowcoder 提高组练习赛-R7
https://www.nowcoder.com/acm/contest/179#question
中间空了两场,因为实在是太难了...
第五场的第二题好像还比较可做,是一个最小生成树的结论题,注意到$2^i$可以认为是二进制下的数,即使把比它小的所有$2^x$全加起来也还是比他小,这一点做题的时候可以用一下.
第六场的第一题是一道很奇怪的题目,给图上的每条边赋一个权值,求从每个点出发的最长路以及整条路径上所有数字组成一个高进制数的最大字典序(注意最长路可能有很多条).这道题首先缩点,如果走到环里了就是无限长,求出最长路,然后建反图.按照最长路的长度降序排序,再更新前面的值,但是这么做只有$60$分,因为只考虑了每个点前一条边的数字大小,如果有两条边的数字是一样的,就成了随机选择,但是沿着这条边接着走时可能就会发现两条路径一优一劣了.所以好像还要根据每个点目前的字典序大小对边排序...?好麻烦啊.
今天的题看起来好像简单一点?
A:https://www.nowcoder.com/acm/contest/179/A
题意概述:小清新模拟题.
# include <cstdio>
# include <iostream>
# include <cstring>
# include <string>
# include <cmath>
# include <algorithm>
# define R register int
# define ll long long using namespace std; const int dx[]={-,-,-,,,,,};
const int dy[]={-,,,-,,-,,};
const int maxn=;
int n,m,k,r,no,T,x,y,w;
int act[maxn][maxn],ope[maxn][maxn],vis[maxn][maxn]; int main()
{
scanf("%d%d%d",&n,&m,&k);
no=k;
for (R i=;i<=n;++i)
for (R j=;j<=m;++j)
{
scanf("%d",&r);
if(r>) act[i][j]=r;
else act[i][j]=-;
}
for (R i=;i<=n;++i)
for (R j=;j<=m;++j)
scanf("%d",&ope[i][j]);
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&x,&y);
if(ope[x][y]==)
{
printf("-1 -1");
return ;
}
if(vis[x][y])
{
printf("-1 -1");
return ;
}
if(no<&&act[x][y]==-)
{
printf("-1 -1");
return ;
}
if(act[x][y]==-)
{
w+=;
no-=;
}
else no+=act[x][y];
if(no>=k) no=k;
vis[x][y]=true;
for (R d=;d<;++d)
{
int xx=x+dx[d];
int yy=y+dy[d];
if(xx<||xx>n||yy<||yy>m) continue;
ope[xx][yy]=true;
}
}
printf("%d %d",no,w);
return ;
}
A
B:https://www.nowcoder.com/acm/contest/179/B
题意概述:每个数字有一种颜色,连到以$1$为根的一棵树上,每个点的父亲必须是它的一个因数,同一颜色且连在一起的算一个联通块,求通过合理的连边能制造的最多联通块。
看起来像是个很难的题目,但是其实贪心就行,只要能连到颜色不同的父亲上就连,不能连就连到$1$上即可.复杂度$O(N\sqrt{N})$.更合理的做法是对于每一个数字枚举倍数,运用调和级数计算复杂度$O(NlogN)$
# include <cstdio>
# include <iostream>
# include <cstring>
# include <string>
# include <cmath>
# include <algorithm>
# define R register int
# define ll long long using namespace std; const int maxn=;
int n,a[maxn],f[maxn],ans,fa,t; int main()
{
scanf("%d",&n);
ans=;
for (R i=;i<=n;++i)
scanf("%d",&a[i]);
for (R i=;i<=n;++i)
{
fa=;
for (R j=;j*j<=i;++j)
{
if(i%j) continue;
t=j;
if(fa==&&a[t]!=a[i])
f[i]=t,ans++,fa=true;
if(j==) continue;
t=i/j;
if(fa==&&a[t]!=a[i])
f[i]=t,ans++,fa=true;
}
if(!fa) f[i]=;
}
printf("%d",ans);
return ;
}
B
C:https://www.nowcoder.com/acm/contest/179/C
题意概述:一个$n$个点$m$条边的无权图,给出多组询问问是否有从$u$到$v$走恰好$l$步的方案数;$n<=100,q<=1000,l<=10^9$
非常板子的矩阵乘法!然而跑的非常慢,于是首先按照询问的$l$排序,分段进行矩阵乘法.然而...爆零了!为什么?离线做之后一定要记得还原成原来的顺序输出!!!
改过来也过不了,听说改成倍增+$bitset$就过了.最近牛客网怎么总是出这种有点卡常的题目啊.
# include <cstdio>
# include <iostream>
# include <cstring>
# include <string>
# include <cmath>
# include <algorithm>
# define R register int
# define ll long long using namespace std; const int maxn=;
int n,m,u,v,q,l,t[];
struct mat
{
int a[maxn][maxn];
void init()
{
memset(a,,sizeof(a));
for (R i=;i<=n;++i)
a[i][i]=;
}
}a,ans,y;
struct ask
{
int l,u,v,id;
}s[];
bool cmp (ask a,ask b)
{
return a.l<b.l;
} mat mul (mat a,mat b)
{
mat c;
memset(c.a,,sizeof(c.a));
for (R i=;i<=n;++i)
for (R j=;j<=n;++j)
for (R k=;k<=n;++k)
{
if(a.a[i][k]&&b.a[k][j]) c.a[i][j]=;
if(c.a[i][j]) break;
}
return c;
} mat qui (mat a,int b)
{
mat ans;
ans.init();
while(b)
{
if(b&) ans=mul(ans,a);
a=mul(a,a);
b=b>>;
}
return ans;
} inline char gc()
{
static char now[<<],*S,*T;
if (T==S)
{
T=(S=now)+fread(now,,<<,stdin);
if (T==S) return EOF;
}
return *S++;
}
inline int read()
{
R x=;
register char ch=gc();
while(!isdigit(ch))
ch=gc();
while(isdigit(ch)) x=(x<<)+(x<<)+ch-'',ch=gc();
return x;
} int main()
{
n=read(),m=read();
for (R i=;i<=m;++i)
{
u=read(),v=read();
a.a[u][v]=true;
}
y=a;
q=read();
for (R i=;i<=q;++i)
s[i].l=read(),s[i].u=read(),s[i].v=read(),s[i].id=i;
sort(s+,s++q,cmp);
ans.init();
for (R i=;i<=q;++i)
{
int p=s[i].l-s[i-].l;
if(p)
{
a=qui(y,p);
ans=mul(ans,a);
}
if(ans.a[ s[i].u ][ s[i].v ]) t[ s[i].id ]=;
}
for (R i=;i<=q;++i)
if(t[i]) puts("YES");
else puts("NO");
return ;
}
C
---shzr
Nowcoder 提高组练习赛-R7的更多相关文章
- Nowcoder 提高组练习赛-R1
https://www.nowcoder.com/acm/contest/172#question 单人报名300元,五人合报免费,于是就和学弟同学学长们组了一个三世同堂的队伍,高一的学长wzhqwq ...
- Nowcoder 提高组练习赛-R3
https://www.nowcoder.com/acm/contest/174#question 今天的题好难呀,只有94个人有分.然后我就爆零光荣 考到一半发现我们班要上物理课,还要去做物理实验( ...
- Nowcoder 提高组练习赛-R2
https://www.nowcoder.com/acm/contest/173#question T1:https://www.nowcoder.com/acm/contest/173/A 题意概述 ...
- nowcoder 提高组模拟赛 选择题 解题报告
选择题 链接: https://www.nowcoder.com/acm/contest/178/B 来源:牛客网 题目描述 有一道选择题,有 \(a,b,c,d\) 四个选项. 现在有 \(n\) ...
- nowcoder 提高组模拟赛 最长路 解题报告
最长路 链接: https://www.nowcoder.com/acm/contest/178/A 来源:牛客网 题目描述 有一张 \(n\) 个点 \(m\) 条边的有向图,每条边上都带有一个字符 ...
- nowcoder提高组2题解
T1 化一下试子就ok code #include<cstdio> #include<algorithm> inline long long read() { long lon ...
- 牛客网NOIP赛前集训营-普及组(第二场)和 牛客网NOIP赛前集训营-提高组(第二场)解题报告
目录 牛客网NOIP赛前集训营-普及组(第二场) A 你好诶加币 B 最后一次 C 选择颜色 D 合法括号序列 牛客网NOIP赛前集训营-提高组(第二场) A 方差 B 分糖果 C 集合划分 牛客网N ...
- 刷题总结——mayan游戏(NOIP2011提高组day2T3)
题目: 题目背景 NOIP2011提高组 DAY1 试题. 题目描述 Mayan puzzle 是最近流行起来的一个游戏.游戏界面是一个 7 行 5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即 ...
- 刷题总结——飞扬的小鸟(NOIP2014提高组)
题目: 题目背景 NOIP2014 提高组 Day1 试题. 题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面 ...
随机推荐
- 微信小程序详细图文教程-10分钟完成微信小程序开发部署发布
很多朋友都认为微信小程序申请.部署.发布很难,需要很长时间. 实际上,微信和腾讯云同是腾讯产品,已经提供了10分钟(根据准备资源情况,已完成小程序申请认证)完成小程序开发.部署.发布的方式.当然,实现 ...
- (六)彻底理解synchronized
1.sychronized简介 在学习知识之前,我们先来看一个现象 public class SynchronizedDemo implements Runnable { private static ...
- Java基础——可变参数
大家都知道main方法的参数就是一个数组类型的,那么它其实也是可以改成不定参数类型.我试了试,并调用了一些弹出来的方法. public class ClassC2 { public static vo ...
- 最短路(hdu2544)Dijkstra算法二
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- 桥接模式(Bridge)
1.概念 桥接模式将抽象部分与它的实现部分分离,使它们都可以独立地变化,属于结构性模式的一种. 2.模式结构 Abstraction(抽象类):定义抽象接口,拥有一个Implementor类型的对象引 ...
- HDU1816(二分+2-SAT)
Get Luffy Out * Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
- Function,Object.creat();
一.Object.creat()使用方法 Object.creat(对象): 功能:实现继承,创建一个原型继承自参数的对象. 什么是原型式继承:就是利用修改原型链的结构(增加一个节点中的成员,删除一个 ...
- 5月8日——iOS中的3D Touch效果
需要在manifest.json文件中进行配置 需要执行的js代码为: 最终操作效果为 本篇文章主要采用了HTML5+ 中的 launcher属性 具体可参照 http://www.html5plu ...
- JS--我发现,原来你是这样的JS(三)(基础概念--灵魂篇)
一.介绍 这是红宝书(JavaScript高级程序设计 3版)的读书笔记第三篇(灵魂篇介绍),有着剩下的第三章的知识内容. 红宝书这本书可以说是难啃的,要看完不容易,挺厚的,要看懂更不容易,要熟练js ...
- linux下安装mysql(ubuntu0.16.04.1)
安装步骤: sudo netstat -tap | grep mysql 查看是否已安装 安装mysql:sudo apt-get install mysql-server mysql-client ...