考虑搜索,发现复杂度爆炸
       贪心,正确性过低(~~实测爆炸~~)

于是,~~发现~~这题是模拟退火

这里不讲解退火的定义了,初学退火可以去平衡点

退火本身维护一个答案图像,答案的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的更多相关文章

  1. 题解 洛谷P5018【对称二叉树】(noip2018T4)

    \(noip2018\) \(T4\)题解 其实呢,我是觉得这题比\(T3\)水到不知道哪里去了 毕竟我比较菜,不大会\(dp\) 好了开始讲正事 这题其实考察的其实就是选手对D(大)F(法)S(师) ...

  2. 题解 洛谷 P3396 【哈希冲突】(根号分治)

    根号分治 前言 本题是一道讲解根号分治思想的论文题(然鹅我并没有找到论文),正 如论文中所说,根号算法--不仅是分块,根号分治利用的思想和分块像 似却又不同,某一篇洛谷日报中说过,分块算法实质上是一种 ...

  3. 题解-洛谷P5410 【模板】扩展 KMP(Z 函数)

    题面 洛谷P5410 [模板]扩展 KMP(Z 函数) 给定两个字符串 \(a,b\),要求出两个数组:\(b\) 的 \(z\) 函数数组 \(z\).\(b\) 与 \(a\) 的每一个后缀的 L ...

  4. 题解-洛谷P4229 某位歌姬的故事

    题面 洛谷P4229 某位歌姬的故事 \(T\) 组测试数据.有 \(n\) 个音节,每个音节 \(h_i\in[1,A]\),还有 \(m\) 个限制 \((l_i,r_i,g_i)\) 表示 \( ...

  5. 题解-洛谷P4724 【模板】三维凸包

    洛谷P4724 [模板]三维凸包 给出空间中 \(n\) 个点 \(p_i\),求凸包表面积. 数据范围:\(1\le n\le 2000\). 这篇题解因为是世界上最逊的人写的,所以也会有求凸包体积 ...

  6. 题解-洛谷P4859 已经没有什么好害怕的了

    洛谷P4859 已经没有什么好害怕的了 给定 \(n\) 和 \(k\),\(n\) 个糖果能量 \(a_i\) 和 \(n\) 个药片能量 \(b_i\),每个 \(a_i\) 和 \(b_i\) ...

  7. 题解-洛谷P5217 贫穷

    洛谷P5217 贫穷 给定长度为 \(n\) 的初始文本 \(s\),有 \(m\) 个如下操作: \(\texttt{I x c}\),在第 \(x\) 个字母后面插入一个 \(c\). \(\te ...

  8. 题解 洛谷 P2010 【回文日期】

    By:Soroak 洛谷博客 知识点:模拟+暴力枚举 思路:题目中有提到闰年然后很多人就认为,闰年是需要判断的其实,含有2月29号的回文串,前四位是一个闰年那么我们就可以直接进行暴力枚举 一些小细节: ...

  9. 题解 洛谷P2158 【[SDOI2008]仪仗队】

    本文搬自本人洛谷博客 题目 本文进行了一定的更新 优化了 Markdown 中 Latex 语句的运用,加强了可读性 补充了"我们仍不曾知晓得 消失的 性质5 ",加强了推导的严谨 ...

随机推荐

  1. Photoshop调出田园照片唯美手绘油画效果

    先看看效果图 原片分析:妹子脸上的光不够通透,有些灰暗,整体色调不够分明. 后期思路:色彩往油画风格调整,让画面色彩更加油润.丰富. 基础调整 (1)曝光根据照片的实际情况进行调整 (2)增加阴影部分 ...

  2. mybatis 一对多查询

    需求:一条数据对应多张表 ad_share_friends  主表 ad_share_image 图片表 建立实体 adShareFriends  和  adShareImage *注意在adShar ...

  3. WMI Explorer操作 和 powershell命令

    powershell查看wmi root 空间 PS C:\Users\yyy> Get-WmiObject -Class __namespace -Namespace root | selec ...

  4. NodeJs连接操作MongoDB数据库

    NodeJs连接操作MongoDB数据库 一,介绍 MongoDB是一种文档导向数据库管理系统,由C++撰写而成.介绍如何使用 Node.js 来连接 MongoDB,并对数据库进行操作. Mongo ...

  5. asp.net core 排序过滤分页组件:sieve(1)

    使用asp.net core开发时避免不了要用一个合适的分页组件来让前端获取分页数据.github上面有一个开源的分页组件在这方面很适合我的使用,于是我把他的文档翻译一下,随后会分析它里面的源码.这是 ...

  6. Linux查看文件大小

    //查看系统中文件的使用情况 df -h //查看当前目录下各个文件及目录占用空间大小 du -sh * //查看welcome.txt文件占用空间大小 du -sh welcome.txt //方法 ...

  7. DAY21、面向对象

    一.内存管理与正则语法1.内存管理:引用计数:垃圾回收机制工作原理 引用就 +1 ,释放就 -1 ,当计数为0时,就会被垃圾回收机制回收标记清除:解决循环导入引用导致的内存泄漏 标记:GC roots ...

  8. python format() 函数

    转载 https://www.cnblogs.com/wushuaishuai/p/7687728.html 正文 Python2.6 开始,新增了一种格式化字符串的函数 format() ,它增强了 ...

  9. HTML&CSS_基础01

    一.预备知识: # 1. HTML5 是 W3C 与 WHATWG 合作的结果.    W3C 指 World Wide Web Consortium,万维网联盟.    WHATWG 指 Web H ...

  10. UOJ#449. 【集训队作业2018】喂鸽子(期望dp)

    题意 有 \(n\) 只鸽子,每只鸽子需要 \(k\) 粒玉米才能喂饱.问每次随意喂给 \(n\) 个鸽子中的一个,期望多久所有鸽子都被喂饱. 对于 \(998244353\) 取模. 数据范围 \( ...