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的更多相关文章

  1. Nowcoder 提高组练习赛-R1

    https://www.nowcoder.com/acm/contest/172#question 单人报名300元,五人合报免费,于是就和学弟同学学长们组了一个三世同堂的队伍,高一的学长wzhqwq ...

  2. Nowcoder 提高组练习赛-R3

    https://www.nowcoder.com/acm/contest/174#question 今天的题好难呀,只有94个人有分.然后我就爆零光荣 考到一半发现我们班要上物理课,还要去做物理实验( ...

  3. Nowcoder 提高组练习赛-R2

    https://www.nowcoder.com/acm/contest/173#question T1:https://www.nowcoder.com/acm/contest/173/A 题意概述 ...

  4. nowcoder 提高组模拟赛 选择题 解题报告

    选择题 链接: https://www.nowcoder.com/acm/contest/178/B 来源:牛客网 题目描述 有一道选择题,有 \(a,b,c,d\) 四个选项. 现在有 \(n\) ...

  5. nowcoder 提高组模拟赛 最长路 解题报告

    最长路 链接: https://www.nowcoder.com/acm/contest/178/A 来源:牛客网 题目描述 有一张 \(n\) 个点 \(m\) 条边的有向图,每条边上都带有一个字符 ...

  6. nowcoder提高组2题解

    T1 化一下试子就ok code #include<cstdio> #include<algorithm> inline long long read() { long lon ...

  7. 牛客网NOIP赛前集训营-普及组(第二场)和 牛客网NOIP赛前集训营-提高组(第二场)解题报告

    目录 牛客网NOIP赛前集训营-普及组(第二场) A 你好诶加币 B 最后一次 C 选择颜色 D 合法括号序列 牛客网NOIP赛前集训营-提高组(第二场) A 方差 B 分糖果 C 集合划分 牛客网N ...

  8. 刷题总结——mayan游戏(NOIP2011提高组day2T3)

    题目: 题目背景 NOIP2011提高组 DAY1 试题. 题目描述 Mayan puzzle 是最近流行起来的一个游戏.游戏界面是一个 7 行 5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即 ...

  9. 刷题总结——飞扬的小鸟(NOIP2014提高组)

    题目: 题目背景 NOIP2014 提高组 Day1 试题. 题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面 ...

随机推荐

  1. 一个div中有一个a标签,点击a标签的时候不进入div的点击事件

    //阻止冒泡上层clickevent.stopPropagation();

  2. 音频播放时出现 Uncaught (in promise) DOMException: play() failed because the user didn't interact with the document first. https://goo.gl/xX8pDD

    <audio id="play" controls="controls" loop="loop"> <source src ...

  3. 数据结构与算法--最小生成树之Kruskal算法

    数据结构与算法--最小生成树之Kruskal算法 上一节介绍了Prim算法,接着来看Kruskal算法. 我们知道Prim算法是从某个顶点开始,从现有树周围的所有邻边中选出权值最小的那条加入到MST中 ...

  4. sqlserver--install/uninstall

    2017 express版本 安装: https://jingyan.baidu.com/article/76a7e409077997fc3a6e1559.html https://www.cnblo ...

  5. Java - "JUC" CyclicBarrier源码分析

    Java多线程系列--“JUC锁”10之 CyclicBarrier原理和示例 CyclicBarrier简介 CyclicBarrier是一个同步辅助类,允许一组线程互相等待,直到到达某个公共屏障点 ...

  6. ubuntn中root密码设置和权限给予

    个人理解: 1.安装ubuntn,会首先要求有一个账号密码设置,比如我设置的:用户名irt,密码**,这是一个普通账户,此时,超级管理账户root密码是空的: 2.给root账户设置密码,大概步骤见下 ...

  7. ionic1项目中 ion-slide轮播用ng-repeat遍历数据后自动循环出问题

    <ion-slide-box>属性中循环播放:dose-continue=‘true’,但是在项目遇到这样一个问题,从后台获取数据后将数据ng-repeat到<ion-slide&g ...

  8. FineReport中如何安装移动端H5插件

    1. HTML5报表插件安装及使用编辑 插件安装 插件网址以及设计器插件安装方法和服务器安装插件的方法可以官网上面搜索,这里就不做详细介绍了. 移动端HTML5报表使用方法 安装好插件后,在浏览器中调 ...

  9. 更多内容 - 请关注我的 CSDN 博客

    欢迎关注我的 CSDN 博客 因为粉丝多数是在 CSDN 上,所以更多内容放在了 我的 CSDN 博客: [点击跳转] 地址:https://icode.blog.csdn.net

  10. 【Redis】Redis学习(六) Redis 基本运维

    Redis的单机搭建,主从搭建,Sentinal搭建,以及Redis集群搭建的步骤参照前面的文章.现在来说一下Redis的基本运维,毕竟如果一切正常是最好的,但是当出现问题不能使用的时候,准确定位问题 ...