题解:uoj632【UR #21】挑战最大团

news/2025/11/17 21:10:05/文章来源:https://www.cnblogs.com/LUlululu1616/p/19234435

题意:给出一个无向图,其满足以下性质:

  • 若存在边 \((a,b),(b,c),(c,d)\),则 \((a,c),(a,d),(b,d)\) 不能同时不存在。

求图中大小为 \(1,2,3\cdots n\) 的团的个数。\(n\le 8000\)

做法:

直接做是 npc,考虑发掘性质。我们会有以下结论:

  • 对于满足条件的图称为好的,那么其补图也是好的。

比较显然,考虑反证那么就等于在原图就会出现违反条件的,矛盾。

  • 对于这样的好图,原图和补图不能同时连通。

考虑归纳,现在加入一个新点,那么如果前面原图不连通现在将其全部连通,也就是对目前所有连通块都连一条边,会发现如果其中有点数 \(\ge 2\) 的连通块,那么就会找到一组三条边的结构,这样就会对所有点都连上一条边,此时补图就不会联通;而如果补图不连通,类似上面对补图讨论就可以得到一样的结论。

所以我们现在就可以得出一个做法:考虑对于原图不连通情况,分成两个部分算团的个数然后相加;对于补图不连通,团在补图上就是一个独立集,两边做一个多项式乘法即可。

暴力做用 bfs 算连通性是 \(O(n^3)\),考虑构造刚好扔掉一个点,复杂度就是 \(\sum i^2 = O(n^3)\),需要优化。

我们还需要一个性质:

  • 好的连通图的直径不超过 \(2\)

根据定义,如果有两个点距离为 \(3\),那么中间会加边距离会变小。

由此我们可以找原图和补图中度数最小的点向外扩展两轮即可,这样保证了我们分成两个连通块的时候,复杂度是小的连通块大小乘上两个连通块大小之和,这个东西假设两个连通块大小分别为 \(x,y\),那么复杂度是 \(O(x(x+y))\)\(O(xy)\) 可以和树上背包分析一样得到为 \(n^2\),而 \(x^2\) 部分为 \(T(n) = n^2+T(\frac n 2)\) 总和也是 \(O(n^2)\),所以总复杂度为 \(O(n^2)\)

代码:

#include <bits/stdc++.h>
using namespace std;
#define int long long
#pragma GCC optimize(2)
const int maxn = 8005, mod = 998244353;
int add(int x, int y) {x += y;return (x >= mod ? x - mod : x);
}
bool f[maxn][maxn];
int n;
inline int get_id(char c) {return (isdigit(c) ? c - '0' : c - 'A' + 10);
}
struct Poly {vector<int> a;int size() {return a.size();}void resize(int N) {a.resize(N);}int& operator[](int x) {return a[x];}friend Poly operator+(Poly f, Poly g) {int d = max(f.size(), g.size());f.resize(d), g.resize(d);for (int i = 0; i < d; i++)f[i] = add(f[i], g[i]);return f;}friend Poly operator*(Poly f, Poly g) {Poly ans; ans.resize(f.size() + g.size() - 1);for (int i = 0; i < f.size(); i++)for (int j = 0; j < g.size(); j++)ans[i + j] = add(ans[i + j], f[i] * g[j] % mod);return ans;}Poly() {a.clear();}
};
int deg[maxn], vis[maxn];
Poly solve(vector<int> &p);
pair<int, Poly> cal(vector<int> &p, int k, int s) {for (int i = 0; i < p.size(); i++)vis[p[i]] = 0;vis[s] = 1;for (int i = 0; i < p.size(); i++) {if(f[s][p[i]] == 1 - k) {vis[p[i]] = 1;for (int j = 0; j < p.size(); j++) {if(!vis[p[j]] && f[p[i]][p[j]] == 1 - k)vis[p[j]] = 1;}}}int f1 = 1;for (int i = 0; i < p.size(); i++) f1 &= vis[p[i]];if(f1)return make_pair(0, Poly());vector<int> lp, rp;Poly res;for (int i = 0; i < p.size(); i++)if(vis[p[i]])lp.push_back(p[i]);elserp.push_back(p[i]);for (int i = 0; i < lp.size(); i++)for (int j = 0; j < rp.size(); j++)deg[lp[i]] -= f[lp[i]][rp[j]],deg[rp[j]] -= f[lp[i]][rp[j]];if(k)res = solve(lp) * solve(rp);elseres = solve(lp) + solve(rp);res[0] = 1;
//	for (int i = 0; i < res.size(); i++)
//		cout << res[i] << " ";
//	cout << endl;return make_pair(1, res);
}
Poly solve(vector<int> &p) {if(p.size() == 1) {Poly res; res.resize(2);res[0] = res[1] = 1;return res;}int r[2] = {0, 0}, mn[2] = {(int)2e9, (int)2e9};for (int i = 0; i < p.size(); i++) {int val[2] = {deg[p[i]], (int)p.size() - 1 - deg[p[i]]};if(val[0] < mn[0])mn[0] = val[0], r[0] = p[i];if(val[1] < mn[1])mn[1] = val[1], r[1] = p[i];}int k = (mn[0] < mn[1] ? 0 : 1);pair<int, Poly> res = cal(p, k, r[k]);if(!res.first)return cal(p, 1 - k, r[1 - k]).second;return res.second;
}
signed main() {ios::sync_with_stdio(false);cin >> n;for (int i = 1; i < n; i++) {string s; cin >> s;for (int j = 1; j <= n - i; j++) {//	cout << (get_id(s[(j - 1) / 4]) >> ((j - 1) % 4)) << endl;f[i][j + i] = ((get_id(s[(j - 1) / 4]) >> ((j - 1) % 4)) & 1), deg[i] += f[i][j + i], deg[j + i] += f[i][j + i],f[j + i][i] = f[i][j + i];}}vector<int> p;for (int i = 1; i <= n; i++)p.push_back(i);Poly res = solve(p); res.resize(n + 1);for (int i = 1; i <= n; i++)cout << res[i] << " ";cout << endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/968304.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[CSP-S 2025] 员工招聘 / employ

P14364 [CSP-S 2025] 员工招聘 / employ 先初步分析一下录取的条件:\(s_i=0\) 此时一定不会被录取 \(s_i=1\) 记之前被淘汰的人数为 \(j\),则若 \(c_{p_i}>j\) 则会被录取,\(c_{p_i}\le j\) 不会被录取。考虑一个…

20232410 2025-2026-1 《网络与系统攻防技术》实验六实验报告

1.实验内容 掌握Metasploit的基础操作:模块搜索(search)、加载(use)、参数配置(set)、攻击执行(exploit/run)及会话管理(sessions)。 理解4类漏洞的核心原理,明确漏洞与靶机开放端口、服务的对应关系。 能…

sequence 题解

原题链接。 首先这个数据范围就很 meet in middle。 首先一个关键性质是对于任意的一个顶到界限的 \(a\) 都能保它顶到界限那一位后面的位数合法,因为它后面随便选就意味着一定能通过调整使得后面的位置异或完是零。 …

2025上海商铺办公室装修公司推荐指南:业态适配与TOP10实力榜

2025上海商铺办公室装修公司推荐指南:业态适配与TOP10实力榜一、商铺装修公司核心评估维度(基于商业空间需求定制) 据《上海市商业空间装饰服务标准(2025 版)》,优质商铺装修服务商需满足六大针对性指标,适配餐…

FastAPI Test Project

# FastAPI Test Project## 项目简介 这是一个使用 FastAPI 框架的测试项目。## 技术栈 - Python >= 3.13 - FastAPI >= 0.121.2 - Uvicorn >= 0.38.0 - uv (包管理工具)## 环境配置### 虚拟环境说明 本项目使…

React Scheduler(调度器)

非常好!React Scheduler(调度器)是React并发能力的引擎,是理解React高性能更新的关键。它独立于React本身,是一个用于在浏览器中调度任务的通用库。 让我们深入剖析React调度器的核心机制。一、调度器是什么?为什…

2025年11月学习机榜单:双线提分机型领衔,十大高性价比之选

2025年11月学习机榜单:双线提分机型领衔,十大高性价比之选孩子放学回家,居家自学缺方法、线下补漏效率低,新课标改革后知识梯度拉升,家长既难同步校内进度,又难精准帮孩子突破薄弱点 —— 这成了 2025 年秋季开学…

Hier-SLAM++ (2) MeshGPT:仅使用解码器Transformer生成三角形网格 - MKT

Hier-SLAM++ (2) MeshGPT:仅使用解码器Transformer生成三角形网格 MeshGPT: Generating Triangle Meshes with Decoder-Only Transformershttps://github.com/audi/MeshGPTMeshGPT通过对经过训练的Transformer模型进…

2025.11.10训练记录

noip模拟赛。 因为喝了咖啡没有睡觉。costa的瓶装拿铁真的特别难喝。 T1 图上加边删边,维护连通块大小的积。 一开始以为直接可撤销并查集就可以做。直接去看T2了,看了一会儿回来实现。 想了一下,感觉也许可以直接撤…

Day41(11)-F:\硕士阶段\Java\课程代码\后端\web-ai-code\web-ai-project02\tlias-web-management

Mybatis 配置文件spring:application:name: springboot-mybatis-quickstart#数据库的连接信息datasource:type: com.alibaba.druid.pool.DruidDataSourceurl: jdbc:mysql://localhost:3306/web01driver-class-name: co…

vue2和vue3声明式和命令时的区别

这是一个非常好的问题,它触及了Vue2到Vue3最核心的演进逻辑。Vue3在保留声明式本质的基础上,通过更底层的命令式API,让开发者能够编写出更具声明性、更易维护的代码。 让我们来深入剖析Vue2和Vue3在声明式与命令式上…

WPS office 2023专业增强版 无限用v12.8 永久激活下载及安装使用教程

激活序列码:TJ3GN-9NTGQ-GLF7C-YEN8X-TJWML WPS Office是由金山软件股份有限公司自主研发的一款办公软件套装,可以实现办公软件最常用的文字、表格、演示等多种功能。 具有内存占用低、运行速度快、体积小巧、强大插…

3D 文件类型,怎么在线查看编辑STL/AMF/OBJ/stp/fbx/ply转换

​ 大致上,数字文件有三种类型:用于打印的、用于建模的和用于二维绘图的。为了生产实体零件,3D打印机需要特定的文件类型。被称为“网格模型”,3D打印中最常见的文件类型称为STereoLithography,简称STL。可以免费…

022304105叶骋恺数据采集第三次作业

作业1 代码与运行结果 class ImageDownloader:def __init__(self):self.headers = {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.…

AI故事生成平台 -

AI故事生成平台通过调用deepseek的apikey,完成了一个基于ai大模型来进行生成故事的平台 通过调用火山方舟豆包的api,使用其文生图对生成的故事进行配图故事页提供多条件查询

nginx rewrite 状态码区别

301 与 308 有了之前的对 302、303、307 的理解,对 301 和 308 的理解就简单多了。 301 Moved Permanently 的定义 301 状态码表明目标资源被永久的移动到了一个新的 URI,任何未来对这个资源的引用都应该使用新的 UR…

GS4:首个泛化高斯溅射语义SLAM框架,十倍效率三维建图 - MKT

GS4:首个泛化高斯溅射语义SLAM框架,十倍效率三维建图

2025 ICPC 南京区域赛 CFGIJ

C. Distributing Candies 思维。 奇数无论怎么分都会分出一个偶数,而奇数不能整除偶数;偶数的话对半分即可。点击查看代码 #include <bits/stdc++.h>using i64 = long long;void solve() {i64 n;std::cin >…

关于一种滚动数组的错误实现方式

滚动数组的大坑!!!!!!!错误写法:swap 一次是 \(O(N)\) 的!!!!!!! int dp[N],dp2[N]; int dodp() {memset(dp,-0x3f,sizeof(dp));memset(dp2,-0x3f,sizeof(dp2));dp2[0]=0;for(int kkk=0;kkk<s.size(…