【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;
}
相关推荐
Coovally AI模型快速验证2 小时前
农田扫描提速37%!基于检测置信度的无人机“智能抽查”路径规划,Coovally一键加速模型落地
深度学习·算法·yolo·计算机视觉·transformer·无人机
pusue_the_sun2 小时前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
RaymondZhao343 小时前
【全面推导】策略梯度算法:公式、偏差方差与进化
人工智能·深度学习·算法·机器学习·chatgpt
zhangfeng11333 小时前
DBSCAN算法详解和参数优化,基于密度的空间聚类算法,特别擅长处理不规则形状的聚类和噪声数据
算法·机器学习·聚类
啊阿狸不会拉杆4 小时前
《算法导论》第 32 章 - 字符串匹配
开发语言·c++·算法
小学生的信奥之路4 小时前
洛谷P3817题解:贪心算法解决糖果分配问题
c++·算法·贪心算法
你知道网上冲浪吗5 小时前
【原创理论】Stochastic Coupled Dyadic System (SCDS):一个用于两性关系动力学建模的随机耦合系统框架
python·算法·数学建模·数值分析
地平线开发者6 小时前
征程 6 | PTQ 精度调优辅助代码,总有你用得上的
算法·自动驾驶
Tisfy7 小时前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
CoovallyAIHub7 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉