LQ0257 金额查错DFS

Posted 海岛Blog

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LQ0257 金额查错DFS相关的知识,希望对你有一定的参考价值。

题目来源:蓝桥杯2011初赛 Java

题目描述
某财务部门结账时发现总金额不对头。很可能是从明细上漏掉了某 1 笔或几笔。如果已知明细账目清单,能通过编程找到漏掉的是哪 1 笔或几笔吗?

如果有多种可能,则输出所有可能的情况。

输入描述
用户输入的第一行是:有错的总金额。

接下来是一个整数 nn,表示下面将要输入的明细账目的条数。

再接下来是 nn 行整数,分别表示每笔账目的金额。

为了方便,不妨假设所有的金额都是整数;每笔金额不超过 1000,金额的明细条数不超过 100。

输出描述
所有可能漏掉的金额组合。每个情况 1 行。金额按照从小到大排列,中间用空格分开。

输入输出样例
示例
输入

6
5
3
2
4
3
1

输出

1 2 4
1 3 3
3 4

问题分析
用DFS来实现枚举搜索。

AC的C++语言程序如下:

/* LQ0257 金额查错 */

#include <iostream>
#include <algorithm>
#include <cstring>

using namespace std;

#define N 100
int msum, n, sum, dsum, a[N], vis[N];

void dfs(int k, int sum)

    if (sum == dsum) 
        for (int i = 0; i < n; i++)
            if (vis[i]) cout << a[i] << " ";
        cout << endl;
     else if (k < n && sum < dsum) 
        if (k > 1 && vis[k - 1] == 0 && a[k] == a[k -1])
            k++;
        vis[k] = 1;
        dfs(k + 1, sum + a[k]);
        vis[k] = 0;
        dfs(k + 1, sum);
    


int main()

    cin >> msum >> n;
    sum = 0;
    for (int i = 0; i < n; i++) 
        scanf("%d", &a[i]);
        sum += a[i];
    
    dsum = sum - msum;

    sort(a, a + n);

    memset(vis, 0, sizeof vis);
    dfs(0, 0);

    return 0;

以上是关于LQ0257 金额查错DFS的主要内容,如果未能解决你的问题,请参考以下文章

LQ0131 字母阵列DFS

LQ0119 全球变暖DFS

LQ0144 方格分割DFS

LQ0109 正则问题DFS

LQ0225 剪格子DFS

LQ0107 剪邮票置换+DFS