【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;
}
相关推荐
阿Y加油吧几秒前
二分查找进阶:旋转排序数组的两道经典题深度解析
数据结构·算法
想带你从多云到转晴5 分钟前
05、数据结构与算法---栈与队列
java·数据结构·算法
無限進步D5 分钟前
蓝桥杯赛后总结
算法·蓝桥杯·竞赛
QuZero10 分钟前
ReentrantLock principle
java·算法
m0_7167652311 分钟前
数据结构--顺序表的插入、删除、查找详解
c语言·开发语言·数据结构·c++·学习·算法·visual studio
Jasmine_llq12 分钟前
《B3954 [GESP202403 二级] 乘法问题》
算法·顺序输入输出算法·布尔标记算法·累乘算法·循环迭代算法·阈值判断算法·条件分支输出算法
Halo_tjn13 分钟前
Java 抽象类 知识点
java·开发语言·算法
say_fall13 分钟前
滑动窗口算法
数据结构·c++·算法
落羽的落羽15 分钟前
【算法札记】练习 | Week1
linux·服务器·c++·人工智能·python·算法·机器学习
人道领域16 分钟前
【LeetCode刷题日记】15.三数之和(梦破碎的地方)
算法·leetcode·面试