L2-052 吉利矩阵

题目描述

题解思路

这个道题就是很简单,就跟n皇后问题一样,给矩阵填数,使得矩阵满足一个什么条件,最后求方案数或者方案。很容易想到回溯法,根据数据范围,应该能够确定回溯法是没有问题的。

我们只需要枚举矩阵的每一个位置,给这个位置填上一个数,如果满足条件,我们就枚举下一个位置。这里的满足条件是指,如果当前位置是某一行的最后一个位置或者某一列的最后一个位置,那么我们需要保证填上这个数之后当前行或列的数字之后等于L

为了实现简单,我们使用xx[]来表示行的和,yy[]来表示列的和。枚举位置的时候我们使用像解八数码问题那样,使用一个数idx来枚举,idx/n就是横坐标,idx%n就是纵坐标,再加上一点剪枝就没有问题。

代码实现

Java

Java超时了,真够离谱的

java 复制代码
import java.util.Scanner;

public class Main {

    static int l, n, ans;
    static int[] xx = new int[5], yy = new int[5];

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        l = in.nextInt();
        n = in.nextInt();
        dfs(0);
        System.out.println(ans);
    }

    public static void dfs(int idx) {
        if (n * n == idx) {
            ans ++;
            return;
        }
        for (int i = 0; i <= l; i ++) {
            int x, y;
            x = idx / n;
            y = idx % n;
            if (xx[x] + i > l || yy[y] + i > l) continue;
            /**
             * if (x == n - 1 && yy[y] + i < l) continue;
             * if (y == n - 1 && xx[x] + i < l) continue;
             * 本来以为是这里浪费时间了,
             * 就改成下边那个,代码速度一定提高了,
             * 但java还是超时, C/C++两个都可以过,下边的更快
             */
            if (x == n - 1 ) i = l - yy[y];
            if (y == n - 1 ) i = l - xx[x];
            xx[x] += i;
            yy[y] += i;
            dfs(idx + 1);
            xx[x] -= i;
            yy[y] -= i;
        }
    }
}

C/C++

cpp 复制代码
#include <iostream>
using namespace std;
int l, n, ans;
int xx[5], yy[5];
void dfs(int);
int main() {
    cin >> l >> n;
    dfs(0);
    cout << ans;
    return 0;
}
void dfs(int idx) {
    if (n * n == idx) {
        ans ++;
        return;
    }
    for (int i = 0; i <= l; i ++) {
        int x, y;
        x = idx / n;
        y = idx % n;
        if (xx[x] + i > l || yy[y] + i > l) continue;
        if (x == n - 1 ) i = l - yy[y];// if (x == n - 1 && yy[y] + i < l) continue;本来是这个,但是我们可以直接让i等于我们需要的那个值。两种都可以过
        if (y == n - 1 ) i = l - xx[x];
        xx[x] += i;
        yy[y] += i;
        dfs(idx + 1);
        xx[x] -= i;
        yy[y] -= i;
    }
}
相关推荐
折哥的程序人生 · 物流技术专研3 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
一条泥憨鱼4 小时前
【Redis】数据类型和常用命令
java·数据库·redis·后端·缓存
云烟成雨TD4 小时前
Spring AI Alibaba 1.x 系列【78】沙箱(Sandbox)
java·人工智能·spring
程序员二叉4 小时前
【Java】 异常高频面试题精讲 | 易错点+对比总结
java·开发语言·面试
玖玥拾4 小时前
C/C++ 基础笔记(十四)多态与模板编程
c语言·c++·多态·模板
周航宇JoeZhou4 小时前
JB3-9-SpringAI(二)
java·ai·agent·多智能体·调度·智能体·观察
好家伙VCC5 小时前
Web Components主题热切换方案揭秘
java·前端
慕木沐5 小时前
Google ADK Java 1.0版本 核心机制与实战 Demo
java·开发语言·python
想吃火锅10055 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
Roann_seo%5 小时前
C++文件操作完全指南:从文本读写到二进制文件处理
开发语言·c++