N—E—E 2021-12-01 22:27 采纳率: 59.5%
浏览 30
已结题

这个组合总和问题哪里错了

问题遇到的现象和发生背景

题目:

img

问题相关代码,请勿粘贴截图
#include <stdio.h>
#include <string.h>

int result[10];
int CurrentNum = 0;

int ValidSize(){
    int size = 0;
    for (int i = 1; i <= 9; i++)
    {
        if (result[i]) size++;
    }
    //printf("the size now is %d\n",size);
    return size;
}

int Sum(){
    int sum;
    for (int i = 1; i < 10; i++)
    {
        if (result[i]) sum += result[i];
    }
    //printf("the sum now is %d\n",sum);
    return sum;
}

void CombineSum(int k,int n,int start){
    if (ValidSize() == k && Sum() == n)
    {
        for (int t = 1; t <= k; t++)
        {
            printf("%d",result[t]);
        }
        printf("\n");
        return;
    }
    for (int i = start; (k - ValidSize() < 9-i+1) && Sum() < n; i++)
    {
        result[++CurrentNum] = i;
        CombineSum(k,n,i+1);
        result[CurrentNum--] = 0;
    }
}

int main()
{
    int n,k;
    memset(result,0,sizeof(result));
    scanf("%d %d",&k,&n);
    CombineSum(k,n,1);
    system("pause");
    return 0;
}


运行结果及报错内容

没有输出,不知道为什么

img

这是加了两条调试语句的输出:

img

我的解答思路和尝试过的方法

不知道是不是for循环剪枝那里出问题了?还是sum函数有问题(输出的sum和回溯算法模拟的不一样)?

  • 写回答

2条回答 默认 最新

  • togolife 2021-12-03 09:48
    关注
    
    #include <stdio.h>
    #include <string.h>
    int result[10];
    int CurrentNum = 0;
    int ValidSize(){
        int size = 0;
        for (int i = 0; i <= 9; i++) // 从下标0开始计算
        {
            if (result[i]) size++;
        }
        //printf("the size now is %d\n",size);
        return size;
    }
    int Sum(){
        int sum = 0; // 初始化
        for (int i = 0; i < 10; i++) // 从数组下标0开始计算
        {
            if (result[i]) sum += result[i];
        }
        //printf("the sum now is %d\n",sum);
        return sum;
    }
    void CombineSum(int k,int n,int start) {
        if (ValidSize() > k) {  // 修改了递归结束条件
            return;
        }
        if (ValidSize() == k) // 将Sum()判断移到内部
        {
            if (Sum() == n) {
                for (int t = 1; t <= k; t++)
                {
                    printf("%d",result[t]);
                }
                printf("\n");
            }
            return;
        }
        for (int i = start; (k - ValidSize() < 9-i+1) && Sum() < n; i++)
        {
            result[++CurrentNum] = i;
            CombineSum(k,n,i+1);
            result[CurrentNum--] = 0;
        }
    }
    int main()
    {
        int n,k;
        memset(result,0,sizeof(result));
        scanf("%d %d",&k,&n);
        CombineSum(k,n,1);
        system("pause");
        return 0;
    }
    
    

    就是微调了几下,问题主要出在:

    1. 递归函数中的判断
    2. Sum函数中sum未初始化
    3. Sum和ValidSize函数中循环数组下标应该从0开始计算
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月11日
  • 已采纳回答 12月3日
  • 赞助了问题酬金 12月2日
  • 创建了问题 12月1日

悬赏问题

  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统