经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C » 查看文章
agc027D - Modulo Matrix(构造 黑白染色)
来源:cnblogs  作者:自为风月马前卒  时间:2018/9/28 16:57:17  对本文有异议

题意

题目链接

构造一个$n * n$的矩阵,要求任意相邻的两个数$a,b$,使得$max(a,b) % min(a,b) \not = 0$

Sol

我的思路:

假设$mod = 1$,那么可以在第一行放2 3 4 5 $\dots$,第一列同理也这样放

对于任意位置$i$,一定满足要求的一个数是a[i - 1][j] * a[i][j - 1] / __gcd(a[i - 1][j], a[i][j - 1]) + 1

然而最后的数大到上天啊。。。

标算挺巧妙的,首先把整个图黑白染色,那么同色点之间是互不影响的。

考虑构造$mod = 1$的矩阵。

若白点的权值确定了,那么黑点的权值应当是所有相邻白点的$lcm$+1,

那所有白点的权值怎么确定呢?

考虑直接用素数填充对于正对角线和负对角线上的每个点分配一个不同的素数

那么任意白点的权值为所在正对角线上的素数 乘 负对角线的素数

这样算出来最大的$a_{ij} = 414556486388264 $,满足要求

不过为啥数组要开1000才能过???

  1. #include<bits/stdc++.h>
  2. #define int long long
  3. using namespace std;
  4. const int MAXN = 1e5 + 10;
  5. int N;
  6. int a[1001][1001], vis[MAXN], prime[MAXN], tot;
  7. void GetPhi() {
  8. vis[1] = 1;
  9. for(int i = 2; i; i++) {
  10. if(!vis[i]) prime[++tot] = i;
  11. if(tot == 1000) break;
  12. for(int j = 1; j <= tot && (i * prime[j] <= 10000); j++) {
  13. vis[i * prime[j]] = 1;
  14. if(!(i % prime[j])) break;
  15. }
  16. }
  17. }
  18. int lcm(int x, int y) {
  19. if(x == 0 || y == 0) return x + y;
  20. return x / __gcd(x, y) * y;
  21. }
  22. main() {
  23. GetPhi();
  24. cin >> N;
  25. if(N == 2) {
  26. printf("4 7\n23 10");
  27. return 0;
  28. }
  29. for(int i = 1; i <= N; i++)
  30. for(int j = 1; j <= N; j++)
  31. if(!((i + j) & 1)) a[i][j] = prime[(i + j) / 2] * prime[N + (i - j) / 2 + (N + 1) / 2];
  32. for(int i = 1; i <= N; i++)
  33. for(int j = 1; j <= N; j++)
  34. if(!a[i][j])
  35. a[i][j] = lcm(lcm(a[i - 1][j], a[i][j - 1]), lcm(a[i][j + 1], a[i + 1][j])) + 1;
  36. for(int i = 1; i <= N; i++, puts(""))
  37. for(int j = 1; j <= N; j++)
  38. cout << a[i][j] << " ";
  39. return 0;
  40. }
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号