P1118 [USACO06FEB] Backward Digit Sums G/S

  • 1≤�≤12
  • 1≤sum≤12345

解题思路

这题的关键是先看出"不断相加"后的结果,本质上是一个加权和。

以 �=4 为例:

复制代码
a1   a2   a3   a4
  a1+a2   a2+a3   a3+a4
    a1+2a2+a3   a2+2a3+a4
      a1+3a2+3a3+a4

最后一行的系数是 1, 3, 3, 1,正好对应杨辉三角的一行。

继续推广可知,最终结果可以写成:

∑�=1���⋅�(�−1,�−1)

于是原题就转化成了:

排列 �1,�2,...,��,找到一个字典序最小的方案,使得

∑�=1���⋅�(�−1,�−1)=sum

所以整道题可以分成两步:

  1. 先预处理出杨辉三角,得到每一位对应的权值。
  2. 再用 DFS 枚举排列,计算当前加权和。

因为题目要求输出字典序最小的解,所以搜索时按 1 ~ n 的顺序枚举。这样第一个满足条件的方案就是答案。

剪枝

设当前已经填到第 idx 位,当前加权和为 cursum

如果 cursum > sum,后面再怎么填也只会更大,就可以直接返回。

复杂度分析

  • 时间复杂度:最坏情况下为 �(�!⋅�)
    需要枚举排列,搜索过程中每个状态的转移是常数级,整体主要由全排列数量决定。
  • 空间复杂度:�(�2)
    其中杨辉三角需要 �(�2),递归栈、路径数组和标记数组需要 �(�)。
    n 的范围较小

代码实现

复制代码
#define rep(i,a,b) for(int i=(int)a;i<int(b);++i)

int n, num;
int c[15][15];     // 杨辉三角
int coef[15];      // 每一位的系数
int path[15];      // 当前排列
bool used[15];
bool found;

void init() {
    rep(i, 0, 13) {
        c[i][0] = c[i][i] = 1;
        rep(j, 1, i) {
            c[i][j] = c[i - 1][j - 1] + c[i - 1][j];
        }
    }
}

void dfs(int idx, int cursum) {
    if (found) return;
    if (cursum > num) return;

    if (idx == n) {
        if (cursum == num) {
            rep(i, 0, n) cout << path[i] << " ";
            cout << '\n';
            found = true;
        }
        return;
    }

    rep(i, 1, n + 1) {
        if (used[i]) continue;
        used[i] = true;
        path[idx] = i;
        dfs(idx + 1, cursum + i * coef[idx]);
        used[i] = false;
    }
}

void solve() {
    init();
    cin >> n >> num;

    rep(i, 0, n) {
        coef[i] = c[n - 1][i];
    }

    dfs(0, 0);
}

易错点

  1. 杨辉三角的预处理
  2. DFS的使用
  3. 要按从小到大的顺序枚举,才能保证第一个找到的是字典序最小解。
  4. 剪枝条件写成 cursum > sum,不要漏掉。
相关推荐
AI科技星1 小时前
32维超复数流形中意识信息场与物质耦合的拓扑动力学
人工智能·学习·算法·数据挖掘·回归·乖乖数学·全域数学
YuK.W2 小时前
Leetcode100: 94.二叉树中序遍历、104.二叉树最大深度、226.翻转二叉树
java·算法·leetcode·二叉树
气泡音人声分离3 小时前
技术解析|均衡器(EQ)工作原理与实操指南:从频率拆分到听感优化
算法·均衡器·音频剪辑
weixin_413063213 小时前
复现 MatchED 边缘检测模型(单张图片重复8次,训练200 epoch)
python·算法·计算机视觉·边缘检测模型
2601_962440843 小时前
计算机毕业设计之jsp教室管理系统
java·开发语言·笔记·分布式·算法·课程设计·推荐算法
AI视频剪辑官3 小时前
播客切片工具选型核心评价维度
网络·人工智能·算法
复杂网络6 小时前
AI 不睡觉,但它比你更会做实验
算法
贵慜_Derek6 小时前
MAI-04|干净数据在工程上意味着什么:MAI 预训练数据治理
人工智能·算法·llm