解题思路:

一看20以内的数据量,DFS,加上剪枝,完全可以承受这个规模数据的打击

注意事项:
1.注意回溯时恢复记忆性变量,比如数组和vector

2.注意初始状态(严谨):

vis[0][0] = true;

path.push_back(0);
rowRec[0] = colRec[0] = 1;
尤其是最后一句,没有的话会造成无解


参考代码:

#include <iostream>
#include <stdio.h>
#include <vector>
#include <math.h>
#include <algorithm>
#define N 20

using namespace std;

int Map[N+2][N+2];
bool vis[N+2][N+2];
int rowRec[N+2], colRec[N+2], rowRequest[N+2], colRequest[N+2];
int rowDir[] = {0, 1, 0, -1};
int colDir[] = {1, 0, -1, 0};

bool checkRec(const int n)
{
	for (int i = 0; i < n; i++)
		if (rowRec[i] != rowRequest[i] || colRec[i] != colRequest[i])
			return false;
	return true;
}

void DFS(int curRow, int curCol, const int n, vector<int>& path, vector<int>& ans)
{
	if (curRow == curCol && curRow == n-1)
	{
		if (checkRec(n))
			ans = path;
		return;
	}
	else
	{
		for (int i = 0; i < 4; i++)
		{
			int newRow = curRow + rowDir[i];
			int newCol = curCol + colDir[i];
			if (newRow >= 0 && newRow < n && newCol >= 0 && newCol < n && !vis[newRow][newCol])
			{
				if (rowRec[newRow] + 1 <= rowRequest[newRow] && colRec[newCol] + 1 <= colRequest[newCol])
				{
					rowRec[newRow] += 1;
					colRec[newCol] += 1;
					path.push_back(Map[newRow][newCol]);
					vis[newRow][newCol] = true;
					DFS(newRow, newCol, n, path, ans);
					vis[newRow][newCol] = false;
					rowRec[newRow] -= 1;
					colRec[newCol] -= 1;
					path.pop_back();
				}
			}
		}
	}
}

int main(void)
{
	int n = 0;
	cin >> n;
	int num = 0;
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < n; j++)
		{
			Map[i][j] = num;
			num += 1;
		}
	}
	
	for (int i = 0; i < n; i++)
		cin >> colRequest[i];
		
	for (int i = 0; i < n; i++)
		cin >> rowRequest[i];
		
	vis[0][0] = true;
	vector<int> path, ans;
	path.push_back(0);
	rowRec[0] = colRec[0] = 1;
	DFS(0, 0, n, path, ans);
	
	for (vector<int>::iterator it = ans.begin(); it < ans.end(); it++)
		cout << *it << " ";
	cout << "\n";
	return 0;
}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论