【团体程序设计天梯赛】L2-052 吉利矩阵

思路:

直接回溯枚举每一个位置填的数,二维肯定是不方便的,我们转成一维,下标x从0到n*n-1。二维数组下标从0到n-1,在一维中下标为x的点在二维中对应行是x/n,列是x%n。

每个数最小能填的是0,最大肯定就是l了,时间复杂度的上限是n的2l次幂,4的18大概是1e11这样。

我们直接标记每行sum和每列sum,因为只有当前填的元素只会影响它所在的行和列,所以只要判断它所在行和列是否满足条件就行了。剪枝一下,具体的就是,当前和不能大于l,因为后面还有元素要加,以及,当前和加上后面元素的最大和能够大于等于l。

代码:

cpp 复制代码
#include <iostream>
using namespace std;
int l,n,row[5],col[5],ans;

void backtrack(int x){
    if(x==n*n){
        for(int i=0;i<n;i++){
            if(row[i]!=l) return;
            if(col[i]!=l) return;
        }
        ans++;
        return;
    }
    for(int i=0;i<=l;i++){//能填的数最小是0,最大是l
        //剪枝1:当前行或列值不超过l
        if(row[x/n]+i>l||col[x%n]+i>l) break;
        row[x/n]+=i;//对应行和更新
        col[x%n]+=i;//对应列和更新
        //剪枝2:加上其他没有填的数(取最大)能达到l
        if(row[x/n]+l*(n-1-x%n)>=l&&col[x%n]+l*(n-1-x/n)>=l)
            backtrack(x+1);
        row[x/n]-=i;//还原现场
        col[x%n]-=i;
    }
}
int main(){
    cin>>l>>n;
    backtrack(0);
    cout<<ans;
    return 0;
}
相关推荐
Matlab程序猿小助手6 分钟前
【MATLAB源码-第303期】基于matlab的蒲公英优化算法(DO)机器人栅格路径规划,输出做短路径图和适应度曲线.
开发语言·算法·matlab·机器人·kmeans
CoderIsArt12 分钟前
CORDIC三角计算技术
人工智能·算法·机器学习
立志成为大牛的小牛12 分钟前
数据结构——二十九、图的广度优先遍历(BFS)(王道408)
数据结构·数据库·学习·程序人生·考研·算法·宽度优先
shark_dev13 分钟前
C++新特性——正则表达式
c++
Alex艾力的IT数字空间15 分钟前
基于PyTorch和CuPy的GPU并行化遗传算法实现
数据结构·人工智能·pytorch·python·深度学习·算法·机器学习
云知谷18 分钟前
【经典书籍】C++ Primer 第16章模板与泛型编程精华讲解
c语言·开发语言·c++·软件工程·团队开发
屁股割了还要学25 分钟前
【Linux入门】常用工具:yum、vim
linux·运维·服务器·c语言·c++·学习·考研
仰泳的熊猫26 分钟前
LeetCode:51. N 皇后
数据结构·c++·算法·leetcode
独自破碎E27 分钟前
LeetCode 381: O(1) 时间插入、删除和获取随机元素 - 允许重复
java·算法·leetcode
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 81: 最大子数组和
java·数据结构·算法·leetcode·决策树·职场和发展·深度优先