目录

题目链接

AGC027 D - Modulo Matrix

题解

从第左上角第一个点开始染色,相邻不同色,染法唯一

那么一个点的四周与他不同色,我们另这个点比四周都大,那么这个点权值可以使lcm(四周的点权值)+1

于是我们就得到了一种构造方案,染色后对一种颜色的点进行赋值,然后另一种颜色的点取lcm

可是....直接这样瞎构造会爆掉1e15

对于一种染色点,可以按照i + j和i - j分为两类,每一类乘上一个相同的质数

对于当前格子的价值就是从左上角到右下角,和从右上角到左下角穿过他的第k素数乘积

这样构造的lcm最大就是四个素数(prime[n],prime[n - 1],prime[2 * n],prime[2 * n - 1])的乘积

不会超过1e15

代码

#include<cstdio>
#include<cctype>
#include<cstring>
#include<algorithm>
#define gc getchar()
#define pc putchar
#define LL long long
inline int read() {
int x = 0,f = 1;
char c = getchar();
while(c < '0' || c > '9') c = gc;
while(c <= '9' && c >= '0') x = x * 10 + c - '0',c = getchar();
return x * f;
}
void print(LL x) {
if(x < 0) {
pc('-');
x = -x;
}
if(x >= 10) print(x / 10);
pc(x % 10 + '0');
}
const int maxn = 20007;
int n;
int prime[maxn];
bool vis[maxn];
void pre(int lim = 10000) {
for(int cnt = 0,i = 2;i <= lim;++ i) {
if(!vis[i]) prime[++ cnt] = i;
for(int j = 1;j <= cnt && prime[j] * i <= lim;++ j) {
vis[i * prime[j]] = 1;
if(i % prime[j] == 0) break;
}
}
}
LL a[507][507];
LL gcd(LL x,LL y) {
return y == 0 ? x : gcd(y,x % y);
}
LL lcm(LL x,LL y) {
return x / gcd(x,y) * y;
}
int main() {
n = read();
pre();
if(n == 2) {
pc('4');pc(' ');pc('7');pc('\n');
print(23);pc(' '); print(10); pc('\n');
return 0;
}
for(int i = 0;i <= n + 1;++ i)
for(int j = 0;j <= n + 1;++ j)
a[i][j] = 1;
for(int i = 1;i <= n;++ i)
for(int j = 1;j <= n;++ j) {
if((j & 1) == (i & 1)) {
a[i][j] = prime[(i + j) / 2] * prime[(i + n + 1 - j) / 2 + n];
a[i + 1][j] = lcm(a[i + 1][j],a[i][j]);
a[i - 1][j] = lcm(a[i - 1][j],a[i][j]);
a[i][j + 1] = lcm(a[i][j + 1],a[i][j]);
a[i][j - 1] = lcm(a[i][j - 1],a[i][j]);
}
}
for(int i = 1;i <= n;++ i)
for(int j = 1;j <= n;++ j)
if((i & 1) == (j & 1));
else a[i][j] ++;
for(int i = 1;i <= n;++ i,pc('\n'))
for(int j = 1;j <= n;++ j)
print(a[i][j]),pc(' ');
return 0;
}

AGC027 D - Modulo Matrix 构造的更多相关文章

  1. AtCoder Grand Contest 027 (AGC017) D - Modulo Matrix 构造

    原文链接https://www.cnblogs.com/zhouzhendong/p/AGC027C.html 题解 首先我们假装 max mod min = 1 然后对着这个构造. 将各自黑白染色, ...

  2. AGC 027D.Modulo Matrix(构造 黑白染色)

    题目链接 \(Description\) 给定\(n\),要求构造一个\(n\times n\)的矩阵,矩阵内的元素两两不同,且任意相邻的两个元素\(x,y\),满足\(\max(x,y)\ \mat ...

  3. agc027D - Modulo Matrix(构造 黑白染色)

    题意 题目链接 构造一个\(n * n\)的矩阵,要求任意相邻的两个数\(a,b\),使得\(max(a,b) \% min(a,b) \not = 0\) Sol 我的思路: 假设\(mod = 1 ...

  4. 「AGC027D」Modulo Matrix

    「AGC027D」Modulo Matrix 传送门 神仙构造题. 首先考虑一个非常自然的思路,我们把棋盘黑白染色后会变成一个二分图,黑色棋子只会与白色棋子相邻. 也就是说,我们可以将二分图的一部随便 ...

  5. hdu 5015 233 Matrix(构造矩阵)

    http://acm.hdu.edu.cn/showproblem.php?pid=5015 由于是个二维的递推式,当时没有想到能够这样构造矩阵.从列上看,当前这一列都是由前一列递推得到.依据这一点来 ...

  6. Educational Codeforces Round 48 (Rated for Div. 2) D 1016D Vasya And The Matrix (构造)

    D. Vasya And The Matrix time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  7. UVA 11149 Power of Matrix 构造矩阵

    题目大意:意思就是让求A(A是矩阵)+A2+A3+A4+A5+A6+······+AK,其中矩阵范围n<=40,k<=1000000. 解题思路:由于k的取值范围很大,所以很自然地想到了二 ...

  8. CF486B OR in Matrix(构造+思维)

    CF486B 一道有趣的思维题 由于or的性质可知只要a[i][j]为1那么b中第i行,第j列将都变成1 相反的,如果b[i][j]是0那么a中第i行,第j列都必须是0 根据第二个性质我们可以构造出a ...

  9. [atAGC027D]Modulo Matrix

    对网格图黑白染色,在黑色格中填不同的质数,白色格中填相邻黑色格的lcm+1,但这样会超过1e15的上限将网格图划分为两类对角线,每一条对角线选一个质数,然后每一个点就是两条对角线的质数相乘,而白格的值 ...

随机推荐

  1. CMake 示例

    1.需求 [1].使用第三方动/静太库 [2].本身代码部分编译为动/静态库 [3]多项目管理 原文转自:http://blog.csdn.net/shuyong1999/article/detail ...

  2. if-else 重构

    最近发现自己写的代码if else太多了,有时候自己回头看都要重新捋逻辑,很不好.决定深入理解下if else重构. 中心思想: ①不同分支应当是同等层次,内容相当. ②合并条件表达式,减少if语句数 ...

  3. class_create(),device_create自动创建设备文件结点【转】

    本文参考来自CSDN博客,转载请标明出处:http://blog.csdn.net/zhenwenxian/archive/2010/03/28/5424434.aspx 本文转自:http://ww ...

  4. xpath与nodejs解析xml

    测试xpath的工具 http://www.freeformatter.com/xpath-tester.html#ad-output http://www.xpathtester.com/test ...

  5. saltstack自动化运维系列②之saltstack的数据系统

    saltstack自动化运维系列②之saltstack的数据系统 grains:搜集minion启动时的系统信息,只有在minion启动时才会搜集,grains更适合做一些静态的属性值的采集,例如设备 ...

  6. PL/SQL第三章 基础查询语句

    --查询所有列 select * from tab_name|view_name; SELECT * FROM emp; SELECT * FROM (SELECT * FROM emp); --查询 ...

  7. Android手势滑动Tab

    Android手势滑动Tab //MainActivity.java public class MainActivity extends TabActivity { ; ; ; private Ges ...

  8. Java基础99 待续

    1.待续 原创作者:DSHORE 作者主页:http://www.cnblogs.com/dshore123/ 原文出自:https://www.cnblogs.com/dshore123/p/107 ...

  9. 在vscode成功配置Python环境

    注意:如果您希望在Visual Studio Code中开始使用Python,请参阅教程.本文仅关注设置Python解释器/环境的各个方面. Python中的“环境”是Python程序运行的上下文.环 ...

  10. TLiteSQLMonitor 使用方法