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. MFC函数—SetRegistryKey

    前言:在用mfc框架编写应用的时候,如果注意,你会发现在App应用类的InitInstance()函数中,初始化时总有一个 SetRegistryKey("String");  这 ...

  2. C#调用百度地图API经验分享(三)

    这一篇我将跟大家分享一下我自己在开发过程中总结出的一些操作地图的方法,属性,及思路,希望可以让大家少走弯路. 1.定位 一般百度的示例DEMO里开始初始化地图时用的都是map.centerAndZoo ...

  3. LoRa术语

    ADR      Adaptive Data Rate          自适应数据率 AES      Advanced Encryption Standard        高级加密标准 AFA  ...

  4. 关于List、Map循环时,进行删除的结论

    通过一些测试发现,List 使用for(int i=0;i<list.size();i++),可以正常删除,不会抛出异常:使用增强for循环,for(String x:list)会抛出Concu ...

  5. docker 知识点汇总

    目录 什么是 Docker Docker 简介 Docker 的特点 如何使用 Docker 镜像的常用操作 容器的常用操作 Docker 命令汇总 手工制作 java 镜像 使用 Dockerfil ...

  6. format格式化字符串

    假如想要表达这样一条语句:李明今年十二岁 输出这样一条语句 name = 'LiMing' age = 12 print( name + 'is' + age + 'years old') #输出 L ...

  7. WebForms开发方式以及优缺点,来源《ASP.NET MVC企业级实战》

    WebForms有以下3种开发方式 1.服务器端控件 2.一般处理程序+HTML静态页+Ajax 3.一般处理程序+HTML模板 WebForms的请求的是具体的某一个文件.具体的一个类,由客户端发送 ...

  8. javascript:类数组 -- 对象

    在javascript中,对象与数组都是这门语言的原生规范中的基本数据类型,处于并列的位置. 类数组:本质是一个对象,只是这个 对象  的属性有点特殊,模拟出数组的一些特性. 一般来说,如果我们有一个 ...

  9. Flask结合Redis消息队列实现电影弹幕

    用到的弹幕播放器插件:dplayer.js(开源) 1.安装Redis 2.安装flask-redis包 pip install flask-redis3.下载dplayer 页面搭建 1.引入资源 ...

  10. 手把手在MyEclipse中搭建Hibernate开发环境

    (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/53414303冷血之心的博客) 在MyEclipse中如何搭建Hib ...