【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;
}
相关推荐
music&movie1 小时前
算法工程师认知水平要求总结
人工智能·算法
laocui12 小时前
Σ∆ 数字滤波
人工智能·算法
yzx9910132 小时前
Linux 系统中的算法技巧与性能优化
linux·算法·性能优化
全栈凯哥3 小时前
Java详解LeetCode 热题 100(26):LeetCode 142. 环形链表 II(Linked List Cycle II)详解
java·算法·leetcode·链表
全栈凯哥3 小时前
Java详解LeetCode 热题 100(27):LeetCode 21. 合并两个有序链表(Merge Two Sorted Lists)详解
java·算法·leetcode·链表
SuperCandyXu3 小时前
leetcode2368. 受限条件下可到达节点的数目-medium
数据结构·c++·算法·leetcode
Humbunklung3 小时前
机器学习算法分类
算法·机器学习·分类
Ai多利3 小时前
深度学习登上Nature子刊!特征选择创新思路
人工智能·算法·计算机视觉·多模态·特征选择
Q8137574604 小时前
中阳视角下的资产配置趋势分析与算法支持
算法
yvestine4 小时前
自然语言处理——文本表示
人工智能·python·算法·自然语言处理·文本表示