每日一题(PTAL2-052):吉利矩阵--dfs

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int res=0;
int sum_row[4]={0};
int sum_col[4]={0};
void dfs(int x,int sum,int width){
    if(x==width*width){
        ++res;
        return;
    }
    for(int i=0;i<=sum;i++){
        if(x % width ==width-1 && i!=sum-sum_row[x / width])continue;
        if(x / width ==width-1 && i!=sum-sum_col[x % width])continue;
        if(sum_row[x / width]+i<=sum && sum_col[x % width]+i<=sum){
            sum_col[x % width]+=i;sum_row[x/width]+=i;
            dfs(x+1,sum,width);
            sum_col[x % width]-=i;sum_row[x/width]-=i;
        }
    } 
}
int main(){
    int sum,width;
    cin>>sum>>width;
    dfs(0,sum,width);
    cout<<res;
    return 0;
}

注意点:

1 利用全局变量res存储个数。

2 和岛屿类似 这里用for循环进行寻找每种情况,并通过一加一减进行回溯

相关推荐
.格子衫.2 分钟前
006贪心——算法备赛
数据结构·算法·leetcode
程序员黄同学27 分钟前
解释观察者模式,如何实现观察者模式?
前端·算法·观察者模式
Repeat71528 分钟前
日志统计(双指针)
java·数据结构·算法·蓝桥杯·双指针·滑动窗口
独好紫罗兰28 分钟前
洛谷题单3-P5725 【深基4.习8】求三角形-python-流程图重构
开发语言·python·算法
明月看潮生2 小时前
青少年编程与数学 02-016 Python数据结构与算法 01课题、算法
数据结构·python·算法·青少年编程·编程与数学
小鱼学习笔记2 小时前
4.1最大子数组和(贪心算法、动态规划)
算法·贪心算法·动态规划
Мартин.2 小时前
[CISSP] [6] 密码学和对称密钥算法
算法·密码学
勤劳的进取家2 小时前
贪心算法之Huffman编码
数据结构·人工智能·算法·数学建模·贪心算法·动态规划
石去皿3 小时前
力扣hot100 61-70记录
c++·算法·leetcode·深度优先
晓纪同学3 小时前
随性研究c++-智能指针
开发语言·c++·算法