题解 洛谷P3936 Coloring
考虑搜索,发现复杂度爆炸
贪心,正确性过低(~~实测爆炸~~)
于是,~~发现~~这题是模拟退火
这里不讲解退火的定义了,初学退火可以去平衡点
退火本身维护一个答案图像,答案的q,当前图像,当前的q
暴力根据计算图像计算q即可
关于这题我们发现如果任由其随机,可能会导致偏差太大
但如果过多修正偏差,可能导致其跃出局部最优解的能力降低
于是我加了这么一句话
if (curq - ansq >= (temp * 90)){
for (ri i = 1; i <= n; ++i)
for (ri j = 1; j <= m; ++j)
cur_map[i][j] = ans_map[i][j];
curq = ansq;
}
即根据当前温度及时修正偏差,温度越高,偏差容忍度越高
最后放个代码(不保证一直AC)
#pragma GCC optimize(2)
#pragma GCC optimize(3)
#pragma GCC optimize("Ofast")
#include <cstdio>
#include <cstdlib>
#include <cmath>
#define ll long long
#define ri register int const double DEL = 0.00001;
const double DELTA = 0.99999; inline ll read(){
ll x = 0; int zf = 1; char ch = ' ';
while (ch != '-' && (ch < '0' || ch > '9')) ch = getchar();
if (ch == '-') zf = -1, ch = getchar();
while (ch >= '0' && ch <= '9') x = x * 10 + ch - '0', ch = getchar(); return x * zf;
} int n, m, c;
int ansq;
int ans_map[25][25];
int curq;
int cur_map[25][25];
int p[25]; inline void swp(int x1, int y1, int x2, int y2){
int t = cur_map[x1][y1];
cur_map[x1][y1] = cur_map[x2][y2];
cur_map[x2][y2] = t;
} inline int getQ(int x1, int y1, int x2, int y2){
int res = 0;
swp(x1, y1, x2, y2);
for (ri i = 1; i <= n; ++i)
for (ri j = 1; j <= m; ++j){
if (i < n)
if (cur_map[i][j] != cur_map[i+1][j])
++res;
if (j < m)
if (cur_map[i][j] != cur_map[i][j+1])
++res;
}
swp(x1, y1, x2, y2);
return res;
} void SA(){
register double temp = 10000.0;
int x1, y1, x2, y2;
int excq;
while (temp >= DEL){
x1 = (rand() % n) + 1, y1 = (rand() % m) + 1, x2 = (rand() % n) + 1, y2 = (rand() % m) + 1;
srand(rand());
excq = getQ(x1, y1, x2, y2);
if (excq < ansq){
curq = ansq = excq;
swp(x1, y1, x2, y2);
for (ri i = 1; i <= n; ++i)
for (ri j = 1; j <= m; ++j)
ans_map[i][j] = cur_map[i][j];
}
else if (exp(-(excq - ansq) / temp) * RAND_MAX > ((rand() % 1000000) / 1000000.0)){
curq = excq;
swp(x1, y1, x2, y2);
}
else{
if (curq - ansq >= (temp * 90)){
for (ri i = 1; i <= n; ++i)
for (ri j = 1; j <= m; ++j)
cur_map[i][j] = ans_map[i][j];
curq = ansq; } }
temp *= DELTA;
}
} int main(){
srand(19260817);
srand(rand()); srand(rand()); srand(rand());
n = read(), m = read(), c = read();
for (ri i = 1; i <= c; ++i)
p[i] = read();
int k1 = 1, k2 = 1;
for (ri i = 1; i <= n; ++i)
for (ri j = 1; j <= m; ++j){
ans_map[i][j] = cur_map[i][j] = k1;
++k2;
if (k2 > p[k1]){
++k1;
k2 = 1;
}
}
ansq = 0;
for (ri i = 1; i <= n; ++i)
for (ri j = 1; j <= m; ++j){
if (i < n)
if (cur_map[i][j] != cur_map[i+1][j])
++ansq;
if (j < m)
if (cur_map[i][j] != cur_map[i][j+1])
++ansq;
}
SA();
for (ri i = 1; i <= n; ++i)
for (ri j = 1; j <= m; ++j){
printf("%d", ans_map[i][j]);
if (j < m)
printf(" ");
else
printf("\n");
}
return 0;
}
题解 洛谷P3936 Coloring的更多相关文章
- 题解 洛谷P5018【对称二叉树】(noip2018T4)
\(noip2018\) \(T4\)题解 其实呢,我是觉得这题比\(T3\)水到不知道哪里去了 毕竟我比较菜,不大会\(dp\) 好了开始讲正事 这题其实考察的其实就是选手对D(大)F(法)S(师) ...
- 题解 洛谷 P3396 【哈希冲突】(根号分治)
根号分治 前言 本题是一道讲解根号分治思想的论文题(然鹅我并没有找到论文),正 如论文中所说,根号算法--不仅是分块,根号分治利用的思想和分块像 似却又不同,某一篇洛谷日报中说过,分块算法实质上是一种 ...
- 题解-洛谷P5410 【模板】扩展 KMP(Z 函数)
题面 洛谷P5410 [模板]扩展 KMP(Z 函数) 给定两个字符串 \(a,b\),要求出两个数组:\(b\) 的 \(z\) 函数数组 \(z\).\(b\) 与 \(a\) 的每一个后缀的 L ...
- 题解-洛谷P4229 某位歌姬的故事
题面 洛谷P4229 某位歌姬的故事 \(T\) 组测试数据.有 \(n\) 个音节,每个音节 \(h_i\in[1,A]\),还有 \(m\) 个限制 \((l_i,r_i,g_i)\) 表示 \( ...
- 题解-洛谷P4724 【模板】三维凸包
洛谷P4724 [模板]三维凸包 给出空间中 \(n\) 个点 \(p_i\),求凸包表面积. 数据范围:\(1\le n\le 2000\). 这篇题解因为是世界上最逊的人写的,所以也会有求凸包体积 ...
- 题解-洛谷P4859 已经没有什么好害怕的了
洛谷P4859 已经没有什么好害怕的了 给定 \(n\) 和 \(k\),\(n\) 个糖果能量 \(a_i\) 和 \(n\) 个药片能量 \(b_i\),每个 \(a_i\) 和 \(b_i\) ...
- 题解-洛谷P5217 贫穷
洛谷P5217 贫穷 给定长度为 \(n\) 的初始文本 \(s\),有 \(m\) 个如下操作: \(\texttt{I x c}\),在第 \(x\) 个字母后面插入一个 \(c\). \(\te ...
- 题解 洛谷 P2010 【回文日期】
By:Soroak 洛谷博客 知识点:模拟+暴力枚举 思路:题目中有提到闰年然后很多人就认为,闰年是需要判断的其实,含有2月29号的回文串,前四位是一个闰年那么我们就可以直接进行暴力枚举 一些小细节: ...
- 题解 洛谷P2158 【[SDOI2008]仪仗队】
本文搬自本人洛谷博客 题目 本文进行了一定的更新 优化了 Markdown 中 Latex 语句的运用,加强了可读性 补充了"我们仍不曾知晓得 消失的 性质5 ",加强了推导的严谨 ...
随机推荐
- nginx 的各种配置
负载均衡 以上是ip的负载均衡,主要是保证 固定ip地址访问到固定服务,如果不做ip的匹配,那么每次请求的机器都不相同,就会出现问题,sessionid 之类的问题 //修改 路由负载均衡不能写has ...
- Java Core - ‘==’和‘equals’的区别
不管是‘==’还是‘equals’,他们的比较都需要区分类型来讨论的: ‘==’ 当比较的数据类型是基本类型时,比较值是否相同 当比较的数据类型是引用类型时,不仅比较值相同还比较其所在内存地址是否相同 ...
- 【MySQL 读书笔记】RR(REPEATABLE-READ)事务隔离详解
这篇我觉得有点难度,我会更慢的更详细的分析一些 case . MySQL 的默认事务隔离级别和其他几个主流数据库隔离级别不同,他的事务隔离级别是 RR(REPEATABLE-READ) 其他的主流数据 ...
- DAY25、面向对象总复习
面向对象总复习:面向过程编程思想: 核心是 过程 二字, 过程指的是解决问题的步骤是,即先干什么再干什么. 基于该编程思想编写程序,相当于一条流水线,一种机械式的思维方式. 面向对象编程思想: 核心是 ...
- 浅谈kafka streams
随着数据时代的到来,数据的实时计算也越来越被大家重视.实时计算的一个重要方向就是实时流计算,目前关于流计算的有很多成熟的技术实现方案,比如Storm.Spark Streaming.flink等.我今 ...
- Python——汇总
一.工具类 (1)pycharm激活.中文破解 (2)pycharm的基本设置 (3)pycharm常用包和插件的安装 二.数据类型 (1)列表.元祖.字典 操作方法 (2)迭代器操作方法 (3)生成 ...
- Go语言中的闭包
一.函数的变量作用域和可见性 1.全局变量在main函数执行之前初始化,全局可见 2.局部变量在函数内部或者if.for等语句块有效,使用之后外部不可见 3.全局变量和局部变量同名的情况下,局部变量生 ...
- C# 将前端传来的图片文件分别以大图和缩略图保存
HttpPostedFile pic_upload = Request.Files["file"]; Bitmap bitmap = (Bitmap)System.Drawing. ...
- 对于CAN ID的理解
本文主要讲的是自己对于CAN ID的理解,希望对需要的人有帮助,本文以通俗的方式来理解,不涉及到具体CAN通信. 在接触CAN之前,应该接触过IIC通信,在IIC通信中,在同一条IIC通信总线上每个d ...
- MySQ数据备份
MySQL备份概述 问题:备份和冗余有什么区别? 备份:能够防止由于机械故障以及人为操作带来的数据丢失,例如将数据库文件保存在了其它地方. 冗余:数据有多份冗余,但不等于备份,只能防止机械故障带来的数 ...