$AT2663$ $Namori$ $Grundy$

题目链接戳这里

简化题意:

题意:有一个弱联通的有向图,含有\(?\)个结点和\(?\)条边。试问是否存在方案,赋给每个结点一个自然数权值\(???_?\),满足对于所有结点\(?\)\(???_?=mex\{???_?|(?,?)\in ?\}\)。一个集合的\(mex\)是没有在这个集合中出现的最小自然数。

显然是个基环树,先考虑在树上的情况。

对于一棵树,完全可以将其叶子的值赋为\(0\),然后再顺次向上做即可,一定存在这样的方案。

在基环树上,最后会化为一个环,每个点有权值,所以我们只要考虑环上的不满足情况即可。

考虑两个在环上相邻的节点\(?\rightarrow ?\),设它们的\(val_u\)\(val_v\)

  • \(val_?>val_v\),那么不需要修改权值。

  • \(val_?=val_?\),那么把\(val_u\)变成\(val_u+1\)
  • \(val_u<val_?\),那么不需要修改权值。

综上,当且仅当环上点权相同且点数为奇数时不存在方案(因为\(+1\)时会死循环)

值得注意的是,对于一个点要先跑完所有子树再将子节点权值加入桶中,计算\(mex\)。不然会在某个子树中出现其他子树的答案。。。

#include<bits/stdc++.h>
using namespace std;
#define int long long
inline int read()
{
    int f=1,w=0;char x=0;
    while(x<'0'||x>'9') {if(x=='-') f=-1; x=getchar();}
    while(x!=EOF&&x>='0'&&x<='9') {w=(w<<3)+(w<<1)+(x^48);x=getchar();}
    return w*f;
}
const int N=200010;
const int INF=1e18;
int num_edge,n,Cnt;
int Cir[N],Vis[N],Val[N];
int head[N<<1],fa[N],Jud[N];
struct Edge{int next,to;} edge[N<<1];
inline void Add(int from,int to)
{
    edge[++num_edge].next=head[from];
    edge[num_edge].to=to;
    head[from]=num_edge;
}
inline void Dfs(int pos)
{
    for(int i=head[pos];i;i=edge[i].next)
        if(!Cir[edge[i].to]) Dfs(edge[i].to);
    for(int i=head[pos];i;i=edge[i].next)
        if(!Cir[edge[i].to]) Jud[Val[edge[i].to]]=1;
    for(;Jud[Val[pos]];Val[pos]++);
    for(int i=head[pos];i;i=edge[i].next)
        if(!Cir[edge[i].to]) Jud[Val[edge[i].to]]=0;
}
main(){
    int pos=1;n=read();
    for(int i=1;i<=n;i++) fa[i]=read(),Add(fa[i],i);
    for(;!Vis[pos];pos=fa[pos]) Vis[pos]=1;
    for(;!Cir[pos];pos=fa[pos]) Cir[pos]=1;
    int Max=-1,Min=INF;
    for(int i=1;i<=n;i++)
        if(Cir[i]) Cnt++,Dfs(i),Max=max(Max,Val[i]),Min=min(Min,Val[i]);
    if(Max==Min&&Cnt&1) puts("IMPOSSIBLE");
    else puts("POSSIBLE");
}

转载于:https://www.cnblogs.com/wo-shi-zhen-de-cai/p/11598083.html

内容概要:本文档主要介绍了Intel Edge Peak (EP) 解决方案,涵盖从零到边缘高峰的软件配置和服务管理。EP解决方案旨在简化客户的入门门槛,提供一系列工具和服务,包括Edge Software Provisioner (ESP),用于构建和缓存操作系统镜像和软件栈;Device Management System (DMS),用于远程集群或本地集群管理;以及Autonomous Clustering for the Edge (ACE),用于自动化边缘集群的创建和管理。文档详细描述了从软件发布、设备制造、运输、安装到最终设备激活的全过程,并强调了在不同应用场景(如公共设施、工业厂房、海上油井和移动医院)下的具体部署步骤和技术细节。此外,文档还探讨了安全设备注册(FDO)、集群管理、密钥轮换和备份等关键操作。 适合人群:具备一定IT基础设施和边缘计算基础知识的技术人员,特别是负责边缘设备部署和管理的系统集成商和运维人员。 使用场景及目标:①帮助系统集成商和客户简化边缘设备的初始配置和后续管理;②确保设备在不同网络环境下的安全启动和注册;③支持大规模边缘设备的自动化集群管理和应用程序编排;④提供详细的密钥管理和集群维护指南,确保系统的长期稳定运行。 其他说明:本文档是详细描述了Edge Peak技术及其应用案例。文档不仅提供了技术实现的指导,还涵盖了策略配置、安全性和扩展性的考虑,帮助用户全面理解和实施Intel的边缘计算解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值