当前位置: 首页 > article >正文

24蓝桥省赛B-数字接龙

#include<bits/stdc++.h>
using namespace std;
const int N=13;
int mp[N][N],flag,n,k;
bool vis[N][N];
int f[N][N][N][N];//存储路径,用于判断是否斜着走,是本题剪枝的难点
vector<int>ans;
vector<int>res;
int dx[]={-1,-1,0,1,1,1,0,-1};
int dy[]={0,1,1,1,0,-1,-1,-1};

bool check1(int x,int y){//坐标合法
    return x>=1&&x<=n&&y>=1&&y<=n;
}

bool check2(int x,int y,int i){//检查是否斜着走
    if(i==0||i==2||i==4||i==6) return true;
    if(i==1&&(f[x-1][y][x][y+1]||f[x][y+1][x-1][y])) return false;
    if(i==3&&(f[x][y+1][x+1][y]||f[x+1][y][x][y+1])) return false;
    if(i==5&&(f[x][y-1][x+1][y]||f[x+1][y][x][y-1])) return false;
    if(i==7&&(f[x][y-1][x-1][y]||f[x-1][y][x][y-1])) return false;
    return true;
}

void dfs(int x,int y,int cnt){//传过来的坐标一定合法、未访问等,line38剪去了不合法的情况
    if(flag) return ;//找到答案时,统统直接返回,也算是剪枝,节省时间
    /*事实上,走到n,n一定可以返回了,也算是种剪枝*/
    if(x==n&&y==n&&cnt==n*n){//走到(n,n)如果有解的话,以一个解即答案(字典序最小)
        res=ans;
        flag=1;
        return ;
    }
    vis[x][y]=1;
    for(int i=0;i<8;i++){
        int nx=x+dx[i];
        int ny=y+dy[i];
        //剪枝
        if(!check1(nx,ny)||vis[nx][ny]) continue;
        if((mp[x][y]+1)%k!=mp[nx][ny]) continue;
        if(!check2(x,y,i)) continue;

        f[x][y][nx][ny]=f[nx][ny][x][y]=1;
        ans.push_back(i);
        dfs(nx,ny,cnt+1);

        //回溯
        f[x][y][nx][ny]=f[nx][ny][x][y]=0;
        vis[nx][ny]=0;
        ans.pop_back();
    }
}

signed main()
{
    cin>>n>>k;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++)
        cin>>mp[i][j];
    }
    dfs(1,1,1);
    if(flag)
    for(auto i:res)
    cout<<i;
    else
    cout<<-1;
}

25/2/18


http://www.kler.cn/a/552398.html

相关文章:

  • 【旋转框目标检测】基于YOLO11/v8深度学习的遥感视角船只智能检测系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】
  • Android Studio 提示 !Failed to initialize editor
  • 力扣LeetCode: 1299 将每个元素替换为右侧最大元素
  • MySQL 窗口函数:功能、使用场景与性能优化
  • 【Arxiv 大模型最新进展】PEAR: 零额外推理开销,提升RAG性能!(★AI最前线★)
  • 【05】密码学与隐私保护
  • vue3项目实践心得-多次渲染同一svg + 理解v-if、transition、dom加载之间的顺序
  • 详解AbstractQueuedSynchronizer(AQS)源码
  • ubantu安装skywalking10.0.0
  • 人工智能 - 脑机融合:人类脑组织操控机器人,具身智能时代的革命性突破
  • Java编程语言:从基础到高级应用的全面探索
  • 构建高效矩阵系统:技术与策略全解析(可OEM)
  • 萃取的实现(三)
  • 【CSS】部分div禁用tailwindcss
  • 【Linux】(32)详解命名管道 | 日志管理 | 进程池2.0
  • WordPress自助建站全攻略
  • 快速排序C++模板,面试常考需背熟
  • 初探ai利用图片生成前端代码
  • 无人机飞手培训机构招生宣传技术详解
  • langchain本地知识库问答机器人集成本地知识库