AtCoder ABC周赛2023 12/10 (Sun) D题题解

目录

原题截图:

题目大意:

主要思路:

注:

代码:


原题截图:

题目大意:

给定两个 的矩阵

你每次可以交换矩阵 的相邻两行中的所有元素或是交换两列中的所有元素。

请问要使 变换至 至少需要几步操作?

如果无法变换至 ,则输出 -1

主要思路:

这个题正解不好想,但我们看一下数据范围:H,W<=5。我们可以暴力bfs,但我们要枚举有效数组,所以用一个map记录,就做成了。

注:

不要再函数中开数组,用vector<vector<int>>。

代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,m;
vector<vector<int>> a(10,vector<int>(10)),b(10,vector<int>(10));
bool equation(vector<vector<int>> a,vector<vector<int>> b)
{
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++)
		{
			if(a[i][j]!=b[i][j])
			{
				return 0;
			}
		}
	}
	return 1;
}
struct node{
	vector<vector<int>> x;
	int cnt;
};
map<vector<vector<int>>,bool> mp;
void bfs()
{
	queue<node> q;
	q.push({a,0});
	mp[a] = 1;
	while(!q.empty())
	{
		node tmp=q.front();
		q.pop();
		if(equation(tmp.x,b))
		{
			cout<<tmp.cnt;
			exit(0);
		}
		for(int i=1;i<n;i++)
		{
			swap(tmp.x[i],tmp.x[i+1]);
			if(!mp.count(tmp.x))
			{
				q.push({tmp.x,tmp.cnt+1});
				mp[tmp.x] = 1;	
			}
			swap(tmp.x[i],tmp.x[i+1]);
		}
		for(int i=1;i<m;i++)
		{
			for(int j=1;j<=n;j++)
			{
				swap(tmp.x[j][i],tmp.x[j][i+1]);
			}
			if(!mp.count(tmp.x))
			{
				q.push({tmp.x,tmp.cnt+1});
				mp[tmp.x] = 1;	
			}
			for(int j=1;j<=n;j++)
			{
				swap(tmp.x[j][i],tmp.x[j][i+1]);
			}
		}
	}	
}
int main()
{
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++)
		{
			cin>>a[i][j];
		}
	}
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++)
		{
			cin>>b[i][j];
		}
	}
	bfs();
	cout<<-1;
	return 0;
}
相关推荐
琪蘤几秒前
点胶换阀高度标定计算说明
算法
handler016 分钟前
算法:查并集
开发语言·数据结构·c++·笔记·学习·算法·c
plus4s6 分钟前
3月19日(进阶10)
算法
Trouvaille ~10 分钟前
【优选算法篇】快速排序模型——从数组划分到快速选择
算法·leetcode·青少年编程·面试·蓝桥杯·快速排序·基础入门
Wect11 分钟前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·算法·typescript
比昨天多敲两行21 分钟前
C++ Lsit
开发语言·c++·算法
我爱C编程22 分钟前
基于OMP正交匹配追踪和稀疏字典构造的杂波谱恢复算法matlab仿真
算法·matlab·omp·正交匹配追踪·稀疏字典构造·杂波谱恢复
云青黛23 分钟前
ReAct(推理与行动)框架
python·算法
im_AMBER34 分钟前
Leetcode 142 将有序数组转换为二叉搜索树 | 排序链表
算法·leetcode
码农三叔36 分钟前
(10-5-01)大模型时代的人形机器人感知:基于RoboBrain大模型的人形机器人通用智能感知系统(1)构建模型
人工智能·算法·机器人·人形机器人