题目1834:蓝桥杯2016年第七届真题-路径之谜

#include<iostream>

using namespace std;

int n;

int a[20],b[20];//a自西向东的靶数,b自北向南的靶数

int arr[20][20];//格子

int vis[20][20];//标记是否访问过

int top;//栈顶

int stack[20];//存储路线的栈

int dx[4]={1,0,-1,0};//下左上右

int dy[4]={0,-1,0,1};//下左上右

bool check(){//检查靶子

for(int i=0;i<n;i++){

if(a[i]!=0||b[i]!=0){

return false;

}

}

return true;

}

void dfs(int x,int y,int step){

if(a[y]<0||b[x]<0){

return;

}

if(x==n-1&&y==n-1){//终止条件,到达最后一个格子

if(check()){

for(int i=0;i<top;i++){

cout<<stack[i]<<" ";

}

cout<<endl;

}

return;

}

for(int i=0;i<4;i++){

int tx,ty;

tx=x+dx[i];

ty=y+dy[i];

if(tx>=0&&tx<n&&ty>=0&&ty<n&&vis[tx][ty]==0){

vis[tx][ty]=1;

stack[top++]=arr[tx][ty];

a[ty]--;

b[tx]--;

dfs(tx,ty,step+1);

a[ty]++;

b[tx]++;

top--;//出栈

vis[tx][ty]=0;

}

}

}

int main(){

cin>>n;

for(int i=0;i<n;i++){

cin>>a[i];

}

for(int i=0;i<n;i++){

cin>>b[i];

}

for(int i=0,k=0;i<n;i++){

for(int j=0;j<n;j++){

arr[i][j]=k++;//为每个格子分配编号

}

}

vis[0][0]=1;

stack[0]=arr[0][0];

top=1;

a[0]--;

b[0]--;

dfs(0,0,1);

return 0;

}

相关推荐
项目申报小狂人1 小时前
基于迁移学习与丢弃法的神经网络算法在无人机失移动目标搜索中的应用,含代码
神经网络·算法·迁移学习
stolentime1 小时前
洛谷P15652 [省选联考 2026] 排列游戏 / perm题解
c++·算法·交互·洛谷·联合省选2026
Darkwanderor2 小时前
数据结构——单调栈和单调队列
数据结构·c++·单调栈·单调队列
机器学习之心2 小时前
198种组合算法+优化SVR支持向量机回归+SHAP分析+新数据预测!机器学习可解释分析,强烈安利,粉丝必备!
算法·shap分析·新数据预测·优化svr支持向量机回归
宵时待雨2 小时前
C++笔记归纳8:stack & queue
开发语言·数据结构·c++·笔记·算法
爱吃生蚝的于勒2 小时前
【Linux】网络基础(一)
linux·运维·服务器·网络·后端·算法·架构
24白菜头2 小时前
第十六届蓝桥杯C&C++大学B组
数据结构·c++·笔记·算法·职场和发展·蓝桥杯
小年糕是糕手2 小时前
【35天从0开始备战蓝桥杯 -- Day2】
开发语言·jvm·数据库·c++·程序人生·考研·蓝桥杯
小年糕是糕手2 小时前
【35天从0开始备战蓝桥杯 -- Day1】
jvm·数据结构·c++·程序人生·算法·职场和发展·蓝桥杯