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. SQL Server 数据库基础知识

    数据库(Database)是由文件管理系统发展起来的,按照数据结构来组织.存储和管理数据的建立在计算机存储设备上的仓库. 特点:       尽可能小的冗余度.       具有较高的数据独立性和易扩 ...

  2. 当堆遇到STL 代码焕发光芒

    来自度娘的释义,堆的含义大概是这样的: 感性理解: 堆(英语:heap)是计算机科学中一类特殊的数据结构的统称.堆通常是一个可以被看做一棵树的数组对象.堆总是满足下列性质: 堆中某个节点的值总是不大于 ...

  3. java基础-面向对象的思想

    一.什么是面向对象 面向对象是一种思想,在java中通常我们会说一句话一切事物即对象.而面向对象到底是怎么回事呢?这里我从人们对问题的思考来阐述,人在思考的一个问题的时候比如在解决一个数学问题的时候我 ...

  4. ActiveMQ 概述

    JMS Java Message Service (Java 消息服务), 类似于JDBC的作用. 1.Destination 目的地 2.Provider 生产者 3.Comsumer 消费者 4. ...

  5. spring-bean实例化三种方式

    在spring中,bean的示例化有三种方式. 1.使用类的无参构造函数创建 2.使用静态工厂方式创建 3.使用实例化工厂方式创建. 具体代码如下 静态工厂方式: Bean2.java package ...

  6. 设计模式之单例模式(Singleton)(1)

    单例模式是一种比较简单的设计模式,简单来说,就是确保一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式特点: 1)单例类只能有一个实例. 2)单例类必须自己创建自己的唯一实例. 3 ...

  7. python的深浅拷贝以及fromkeys的用法

    1.join()的用法:使用前面的字符串.对后面的列表进行拼接,拼接结果是一个字符串 # lst = ["alex","dsb",'wusir','xsb'] ...

  8. flex兼容性问题

    flex在众多手机浏览器上的兼容方案(亲测华为手机自带浏览器) 如果项目使用构建工具,可加autoprefixer来处理,[autoprefixer使用指南] 纯手写css兼容代码,需给每个使用的属性 ...

  9. 前端开发笔记(3)css基础(中)

    上一篇中我们学习了html的标准文档流,下面我们先来看看如何脱离标准流. 脱离标准流 css中一共有三种方法脱离标准流 浮动 绝对定位 固定定位 浮动 我们要搞清楚什么是浮动,先来看一个标准文档流的例 ...

  10. windows下搭建Consul分布式系统和集群

    随着大数据时代的到来,分布式是解决大数据问题的一个主要手段,随着越来越多的分布式的服务,如何在分布式的系统中对这些服务做协调变成了一个很棘手的问题.我们在一个项目上注册了很多服务,在进行运维时,需要时 ...