AtCoder Grand Contest 027 (AGC017) D - Modulo Matrix 构造
原文链接https://www.cnblogs.com/zhouzhendong/p/AGC027C.html
题解
首先我们假装 max mod min = 1
然后对着这个构造。
将各自黑白染色,将所有黑色格子都放不同的质数,白色格子的数为他周围的黑格子的LCM + 1,这样显然是合法的。
但是数字太大了。
稍稍升级一下构造方法。
先假设所有黑格子都是 1.
对于每一个 ' \ ' 形斜列,我们让同一列的乘上一个相同的质数。
对于每一个 ' / ' 形的类似。
这样我们白格子的值就是四个小质数的乘积+1了。
基本上可以过了。
但是,被卡常数了。
实测发现前1000个质数都在7300以内,也就是说前500个质数在大约3150以内,用前500个质数然 ' \ ' 形的,剩下的染 ' / ' 形的就好了。
还有一个细节!
n = 2 的时候要特判!至于为什么一看就知道了。直接把样例抄过来就好了。
代码
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
LL read(){
LL x=0;
char ch=getchar();
while (!isdigit(ch))
ch=getchar();
while (isdigit(ch))
x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
return x;
}
const int N=505;
int n;
vector <int> vp;
LL g[N][N];
LL gcd(LL x,LL y){
return y?gcd(y,x%y):x;
}
LL lcm(LL x,LL y){
if (!x||!y)
return x+y;
return x/gcd(x,y)*y;
}
int check(int n){
for (int i=2;i*i<=n;i++)
if (n%i==0)
return 0;
return 1;
}
map <int,int> mp1,mp2;
int g1(int x){
if (!mp1[x])
mp1[x]=vp.back(),vp.pop_back();
return mp1[x];
}
int g2(int x){
if (!mp2[x])
mp2[x]=vp.back(),vp.pop_back();
return mp2[x];
}
int main(){
n=read();
if (n==2){
puts("4 7");
puts("23 10");
return 0;
}
for (int i=2;vp.size()<n*2;i++)
if (check(i))
vp.push_back(i);
reverse(vp.begin(),vp.end());
mp1.clear(),mp2.clear();
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
if ((i+j)%2==0)
g[i][j]=g1(i+j);
for (int i=n;i>=1;i--)
for (int j=n;j>=1;j--)
if ((i+j)%2==0)
g[i][j]*=g2(i-j);
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
if ((i+j)%2==1)
g[i][j]=lcm(g[i-1][j],lcm(g[i+1][j],lcm(g[i][j-1],g[i][j+1])))+1;
for (int i=1;i<=n;i++,puts(""))
for (int j=1;j<=n;j++)
printf("%lld ",g[i][j]);
return 0;
}
AtCoder Grand Contest 027 (AGC017) D - Modulo Matrix 构造的更多相关文章
- AtCoder Grand Contest 027 C ABland Yard
ABland Yard 思路: 用了类似拓扑排序的方法来判环 代码: #pragma GCC optimize(2) #pragma GCC optimize(3) #pragma GCC optim ...
- AtCoder Grand Contest 030 (AGC030) C - Coloring Torus 构造
原文链接https://www.cnblogs.com/zhouzhendong/p/AGC030C.html 题解 才发现当时是被题意杀了. 当时理解的题意是“对于任意的 (i,j) ,颜色 i 和 ...
- AtCoder Grand Contest 003
AtCoder Grand Contest 003 A - Wanna go back home 翻译 告诉你一个人每天向哪个方向走,你可以自定义他每天走的距离,问它能否在最后一天结束之后回到起点. ...
- AtCoder Grand Contest 012
AtCoder Grand Contest 012 A - AtCoder Group Contest 翻译 有\(3n\)个人,每一个人有一个强大值(看我的假翻译),每三个人可以分成一组,一组的强大 ...
- AtCoder Grand Contest 011
AtCoder Grand Contest 011 upd:这篇咕了好久,前面几题是三周以前写的... AtCoder Grand Contest 011 A - Airport Bus 翻译 有\( ...
- AtCoder Grand Contest 031 简要题解
AtCoder Grand Contest 031 Atcoder A - Colorful Subsequence description 求\(s\)中本质不同子序列的个数模\(10^9+7\). ...
- AtCoder Grand Contest 010
AtCoder Grand Contest 010 A - Addition 翻译 黑板上写了\(n\)个正整数,每次会擦去两个奇偶性相同的数,然后把他们的和写会到黑板上,问最终能否只剩下一个数. 题 ...
- AtCoder Grand Contest 009
AtCoder Grand Contest 009 A - Multiple Array 翻译 见洛谷 题解 从后往前考虑. #include<iostream> #include< ...
- AtCoder Grand Contest 008
AtCoder Grand Contest 008 A - Simple Calculator 翻译 有一个计算器,上面有一个显示按钮和两个其他的按钮.初始时,计算器上显示的数字是\(x\),现在想把 ...
随机推荐
- python发送smtp 邮件 图片
#-*- coding: utf-8 -*- # python2 import os import time import random import smtplib from time import ...
- BSGS算法
BSGS算法 我是看着\(ppl\)的博客学的,您可以先访问\(ppl\)的博客 Part1 BSGS算法 求解关于\(x\)的方程 \[y^x=z(mod\ p)\] 其中\((y,p)=1\) 做 ...
- <Android基础>(三) UI开发 Part 2 ListView
ListView 1)ListView的简单用法 2)定制ListView界面 3)提升ListView的运行效率 4)ListView的点击事件 3.5 ListView 3.5.1 ListVie ...
- [mstsc]解决win8 win10 平板无法被mstsc连接的问题
问题如下: https://answers.microsoft.com/zh-hans/windows/forum/windows_8-performance/win8%E6%97%A0%E6%B3% ...
- Sequence II HDU - 5919(主席树)
Mr. Frog has an integer sequence of length n, which can be denoted as a1,a2,⋯,ana1,a2,⋯,anThere are ...
- 【洛谷P1313 计算系数】
题目连接 #include<algorithm> #include<iostream> #include<cstring> #include<cstdio&g ...
- (四)窗口mainwindow
常用控件: lable: 可以放文本,图片,动态图片,链接 Text Edit: 富文本编辑框:多行文本,HTML,图片 Line Edit: 只能放一行 Plain Edit: 只能显示多行文本 ...
- 任意模数NTT学习笔记
这两天有点颓,所以东西学的也很慢...这个一眼就能推出来的活生生卡了我两天.. 说几个细节: 柿子: \[f*g = (\frac{f}{M} +f\%m)*(\frac{g}{M} +g\%m) \ ...
- Hadoop记录-queue mysql
#!/bin/sh ip=10.116.100.11 port=8088 export HADOOP_HOME=/app/hadoop/bin rmstate1=$($HADOOP_HOME/yarn ...
- 关于java集合的练习
关于java集合的练习 练习一:Collection集合练习 一.产生10个1-100的随机数,并放到一个数组中,把数组中大于等于10的数字放到一个list集合中,并打印到控制台. public cl ...