【Codeforces】 CF1734E Rectangular Congruence

题目链接

CF方向
Luogu方向

题目解法

暂时不考虑 b i b_i bi 的限制

考虑构造 a i , j = i j a_{i,j}=ij ai,j=ij,

那么 a r 1 , c 1 + a r 2 , c 2 = r 1 c 1 + r 2 c 2 ,    a r 1 , c 2 + a r 1 , c 2 = r 1 c 2 + r 2 c 1 a_{r1,c1}+a_{r2,c2}=r1c1+r2c2,\;a_{r1,c2}+a_{r1,c2}=r1c2+r2c1 ar1,c1+ar2,c2=r1c1+r2c2,ar1,c2+ar1,c2=r1c2+r2c1

因为 ( r 1 − r 2 ) ( c 1 − c 2 ) ≢ 0 ( m o d    n ) (r1-r2)(c1-c2)\not\equiv0(mod\;n) (r1−r2)(c1−c2)≡0(modn)

所以这是一组合法的解

考虑对行或列整体添加一个数仍是合法的,考虑调整行即可

感觉令 a i , j = i j a_{i,j}=ij ai,j=ij 的构造还挺妙的

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N(400);
int n,b[N],a[N][N];
inline int read(){
	int FF=0,RR=1;
	char ch=getchar();
	for(;!isdigit(ch);ch=getchar()) if(ch=='-') RR=-1;
	for(;isdigit(ch);ch=getchar()) FF=(FF<<1)+(FF<<3)+ch-48;
	return FF*RR;
}
int main(){
	n=read();
	for(int i=1;i<=n;i++) b[i]=read();
	for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) a[i][j]=i*j;
	for(int i=1;i<=n;i++){
		int del=a[i][i]-b[i];
//		cout<<del<<'\n';
		for(int j=1;j<=n;j++) a[i][j]=((a[i][j]-del)%n+n)%n;
	}
	for(int i=1;i<=n;i++){
		for(int j=1;j<=n;j++) printf("%d ",a[i][j]);
		puts("");
	}
	return 0;
}
相关推荐
Eward-an4 分钟前
LeetCode 76. 最小覆盖子串(详细技术解析)
python·算法·leetcode·职场和发展
guygg887 分钟前
基于ADMM的MRI-PET高质量图像重建算法MATLAB实现
开发语言·算法·matlab
moonlight030410 分钟前
类加载子系统
java·jvm·算法
baivfhpwxf202316 分钟前
ACS X轴回零程序 项目实战版
网络·数据库·算法
一叶落43829 分钟前
LeetCode 219. 存在重复元素 II(C语言详解)
算法·哈希算法·散列表
像污秽一样32 分钟前
算法设计与分析-习题2.4
数据结构·算法·排序算法
不想看见40433 分钟前
Reverse Bits位运算基础问题--力扣101算法题解笔记
笔记·算法·leetcode
罗湖老棍子1 小时前
【例 2】数星星 Stars(信息学奥赛一本通- P1536)
数据结构·算法·树状数组·单点修改 区间查询
逆境不可逃1 小时前
LeetCode 热题 100 之 394. 字符串解码 739. 每日温度 84. 柱状图中的最大矩形
算法·leetcode·职场和发展
重生之后端学习1 小时前
62. 不同路径
开发语言·数据结构·算法·leetcode·职场和发展·深度优先