Solution -「CF 1586F」Defender of Childhood Dreams
Link.
定义有向图 ,,。求一个对 的染色 ,使得 ,同时最小化 的值域大小。
。
设 的值域大小为 ,断言:。
证明 该结论的等价表述是,若 值域大小为 ,则 。当 时显然成立。接下来对 进行归纳:
任取一个 值域大小为 的,被合法染色的图 ,并任取某种颜色 ,据此将点集 划分为 ,使得 的导出子图中不存在颜色为 的边。这些点集之间的连边颜色全部为 ,所以 。而仅考虑某个 的导出子图,它至多用 中颜色染色,由归纳假设,,继而 。
模仿归纳方法得到构造方法:划分点集,将点集之间的边染色,而后递归处理。复杂度上限为 。
/*+Rainybunny+*/
#include <bits/stdc++.h>
#define rep( i, l, r ) for ( int i = l, rep##i = r; i <= rep##i; ++i )
#define per( i, r, l ) for ( int i = r, per##i = l; i >= per##i; --i )
const int MAXN = 1e3;
int n, k, mxc, ans[MAXN + 5][MAXN + 5];
inline void solve( const int l, const int r, const int clr ) {
if ( l == r ) return ;
if ( clr > mxc ) mxc = clr;
int s = ( r - l + k ) / k;
for ( int i = l; i <= r; i += s ) {
solve( i, std::min( i + s - 1, r ), clr + 1 );
rep ( u, l, i - 1 ) rep ( v, i, std::min( i + s - 1, r ) ) {
ans[u][v] = clr;
}
}
}
int main() {
scanf( "%d %d", &n, &k );
solve( 1, n, 1 );
printf( "%d\n", mxc );
rep ( i, 1, n ) rep ( j, i + 1, n ) printf( "%d ", ans[i][j] );
putchar( '\n' );
return 0;
}
分类:
A.算法/知识点 / 构造
, C.特殊题目 / 思维
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
2020-10-20 Solution -「LGR-087」「洛谷 P6860」象棋与马