题目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;

}

相关推荐
小饕10 小时前
从 Word2Vec 到多模态:词嵌入技术的演进全景
人工智能·算法·机器学习
海参崴-10 小时前
AVL树完整实现与深度解析
算法
一个爱编程的人10 小时前
一个数是不是素数
数据结构·算法
Hui_AI72010 小时前
基于RAG的农产品GEO溯源智能问答系统实现
开发语言·网络·人工智能·python·算法·创业创新
lwf00616410 小时前
FFM (Field-aware Factorization Machine) 学习日记
算法·机器学习
南宫萧幕10 小时前
HEV能量管理控制算法实战:从MPC/RL理论基础到Simulink闭环建模
算法·matlab·汽车·控制·pid
charlie11451419110 小时前
通用GUI编程技术——图形渲染实战(三十八)——顶点缓冲与输入布局:GPU的第一个三角形
开发语言·c++·学习·图形渲染·win32
IT猿手10 小时前
SCI一区:章鱼优化算法(Octopus Optimization Algorithm, OOA)求解23个测试函数,出图丰富,提供完整MATLAB代码
开发语言·算法·matlab
superior tigre10 小时前
739 每日温度
算法·leetcode·职场和发展
用户8055336980310 小时前
现代Qt开发教程(新手篇)1.10——进程
c++·qt