I.像素放置【蓝桥杯】/dfs+剪枝

像素放置




dfs+剪枝

思路:利用dfs填入0或者1,并利用数字进行判断,另外这一题数组要从1开始而不是0,这样在num方法中可以少了判断的操作

cpp 复制代码
#include<iostream>
using namespace std;
//a数组存储输入的值,下划线则为-1
//ans数组存储填的01值
int a[15][15],ans[15][15];
bool flag=0;
int n,m;
int b[9][2]={{-1,-1},{-1,0},{-1,1},{0,-1},{0,0},{0,1},{1,-1},{1,0},{1,1}};
//判断该数字格子周围九个点是否符合
bool num(int x,int y)
{
    int res=0,big=a[x][y];
    for(int i=0;i<9;i++)
    {
        int xx=x+b[i][0];
        int yy=y+b[i][1];
        if(ans[xx][yy]==1) res++;
        if(res>big) return 0;
    }
    return res==big;
}
//检查某个点之前的数字点是否符合
bool checksub(int x,int y)
{
    //假设到了x,y点,则x-2这一行及前面的九个格都已经填完
    //细节:要从后往前遍历,否则会超时两个案例,因为其实前面有的已经判断过了,先判断后面的更快找到不符合的
    for(int i=x-2;i>=1;i--)
    {
        for(int j=m;j>=1;j--)
        {
            if(a[i][j]==-1) continue;
            if(!num(i,j)) return 0;
        }
    }

    //x上一行y-2列及前面列周围九个格都已经填完
    if(x>=2)
    {
        for(int j=y-2;j>=1;j--)
        {
            if(a[x-1][j]==-1) continue;
            if(!num(x-1,j)) return 0;
        }
    }
    return 1;
}
//检查所有格子是否符合
bool checkall()
{
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            if(a[i][j]==-1) continue;
            if(!num(i,j)) return 0;
        }
    }
    return 1;
}
void dfs(int x,int y)
{
    //flag为1,表示已经找到唯一的解,直接返回
    if(flag) return ;
    if(!checksub(x,y)) return ;
    //全部遍历完
    if(x==n+1)
    {
        if(checkall())
        {
            flag=1;
            for(int i=1;i<=n;i++)
            {
                for(int j=1;j<=m;j++)
                {
                    printf("%d",ans[i][j]);
                }
                printf("\n");
            }
            return ;
        }
        return ;
    }
    //遍历到最后一列
    if(y==m)
    {
        ans[x][y]=1;
        dfs(x+1,1);
        ans[x][y]=0;
        dfs(x+1,1);
        return ;
    }
    ans[x][y]=1;
    dfs(x,y+1);
    ans[x][y]=0;
    dfs(x,y+1);
    return ;
}
int main()
{
    cin>>n>>m;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            char ch;
            cin>>ch;
            if(ch=='_') a[i][j]=-1;
            else a[i][j]=ch-'0';
        }
    }
    dfs(1,1);
    return 0;
}
相关推荐
前端小超超3 天前
capacitor配置ios应用图标不同尺寸
ios·蓝桥杯·cocoa
手握风云-3 天前
回溯剪枝的 “减法艺术”:化解超时危机的 “救命稻草”(二)
算法·机器学习·剪枝
DogDaoDao4 天前
神经网络稀疏化设计构架方法和原理深度解析
人工智能·pytorch·深度学习·神经网络·大模型·剪枝·网络稀疏
纪元A梦4 天前
贪心算法应用:神经网络剪枝详解
神经网络·贪心算法·剪枝
汉克老师5 天前
第十四届蓝桥杯青少组C++选拔赛[2023.1.15]第二部分编程题(4 、移动石子)
c++·算法·蓝桥杯·蓝桥杯c++·c++蓝桥杯
旭意5 天前
C++微基础蓝桥杯之旅9.9-9.12
c++·算法·蓝桥杯
GawynKing6 天前
图论3 图的遍历
算法·深度优先
HAH-HAH6 天前
【蓝桥杯 2024 国 Java A】粉刷匠小蓝
c++·学习·数学·算法·职场和发展·蓝桥杯·组合数学
汉克老师6 天前
第十四届蓝桥杯青少组C++选拔赛[2023.1.15]第二部分编程题(2 、寻宝石)
c++·蓝桥杯·蓝桥杯c++·c++蓝桥杯·蓝桥杯选拔赛
汉克老师7 天前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(5、机甲战士)
c++·算法·蓝桥杯·01背包·蓝桥杯c++·c++蓝桥杯