当前位置: 首页 > news >正文

P3349 [ZJOI2016] 小星星 - Link

先枚举一个集合 \(S\),设状态 \(f_{i,j}\) 表示树上 \(i\) 号点对应图上 \(j\) 号点 \((j\in S)\) 的方案数(可以多个树上的点对应一个图上的点)。转移是简单的。最后对于集合 \(S\),有容斥系数 \((-1)^{\left|S\right|}\),然后就做完了。

代码

#include<bits/stdc++.h>
using namespace std;
namespace IO{template<typename T>inline void read(T&x){x=0;char c=getchar();bool f=0;while(!isdigit(c)) c=='-'?f=1:0,c=getchar();while(isdigit(c)) x=x*10+c-'0',c=getchar();f?x=-x:0;}template<typename T>inline void write(T x){if(x==0){putchar('0');return ;}x<0?x=-x,putchar('-'):0;short st[50],top=0;while(x) st[++top]=x%10,x/=10;while(top) putchar(st[top--]+'0');}inline void read(char&c){c=getchar();while(isspace(c)) c=getchar();}inline void write(char c){putchar(c);}inline void read(string&s){s.clear();char c;read(c);while(!isspace(c)&&~c) s+=c,c=getchar();}inline void write(string s){for(int i=0,len=s.size();i<len;i++) putchar(s[i]);}template<typename T>inline void write(T*x){while(*x) putchar(*(x++));}template<typename T,typename...T2> inline void read(T&x,T2&...y){read(x),read(y...);}template<typename T,typename...T2> inline void write(const T x,const T2...y){write(x),putchar(' '),write(y...),sizeof...(y)==1?putchar('\n'):0;}
}using namespace IO;
#define int long long
const int maxn=20;
int n,m,f[maxn][maxn],s;
vector<int>e[maxn],g[maxn];
void dfs(int u,int fa=0){for(int i=1;i<=n;i++) f[u][i]=1;for(int v:e[u]){if(v==fa) continue;dfs(v,u);for(int i=1;i<=n;i++){if(!(s&(1<<i-1))) continue;int h=0;for(int vv:g[i]) if(s&(1<<vv-1)) h+=f[v][vv];f[u][i]*=h;}}
}
signed main(){read(n,m);for(int i=1;i<=m;i++){int u,v;read(u,v);g[u].push_back(v);g[v].push_back(u);}for(int i=1;i<n;i++){int u,v;read(u,v);e[u].push_back(v);e[v].push_back(u);}int ans=0;for(int i=0;i<(1<<n);i++){s=i;dfs(1);int gs=0,h=0;for(int j=1;j<=n;j++) if((1<<j-1)&i) gs++,h+=f[1][j];if((n-gs)&1) ans-=h;else ans+=h;}write(ans);return 0;
}
http://www.jsqmd.com/news/254821/

相关文章:

  • 企业如何破解业法财融合痛点?AI风控探针的 4 个落地步骤
  • Nature发表、Science点赞!清华揭秘AI让科学家走捷径却让科学走窄路
  • 【RAG召回排序】2025最全排序模型梳理
  • AI技术唾手可得的时代,挖掘新需求是产品突围的关键——某知名聚合DNS管理系统的需求洞察
  • 编程已终结!AI时代的原生智能软件架构长啥样?Claude给了个指南
  • 安卓神器 --- 浏览器 之 yandex 狐猴浏览器 chrome firefox
  • P11714 [清华集训 2014] 主旋律 Sol
  • 夏天还不算开始——我,不会退役
  • GD5F1GM7UEYIGR:兆易创新1Gbit SPI NAND闪存,高效低功耗
  • 4B超越8B比肩30B!清华、面壁智能端侧智能体天花板开源
  • 企业软件供应链安全治理立项,方案书/立项书该怎么写?
  • [Non] 字符串问题
  • 谷歌Veo 3.1更新:更一致性、更具创造力和控制力
  • 评正高写书10万字什么价格?
  • Day15对象的方法与遍历对象
  • SCI分区是怎么划分的?
  • 深圳ACFlow智能营销系统:2026年中小企业AI驱动营销新范式
  • ACP:2.从一个 .NET 实战开始,看 Agent 带来的真实差异
  • 工业级文本转SQL新思路:成本暴降、超3000列超大数据库依然稳健
  • C++跨平台开发挑战的技术
  • 万卡的部署架构
  • IDM插件开发创意赛
  • Claude Code 在 Windows 下的 nul 文件问题解决方案
  • 建模智能体,AI 时代的数据治理新范式
  • DCDN和CDN科普:动态内容加速的秘密武器
  • 苹果手机照片怎么导入电脑?苹果手机传输照片就用这5招
  • 7843784538745
  • 探索AI原生应用领域,AI代理引领新潮流
  • LLM伦理推理让临床决策更公平
  • 从ChatBI到Agentic BI:衡石如何构建“自主决策与执行”的数据智能体