【蓝桥杯】分糖果(DFS)

问题描述

两种糖果分别有 9个和 16 个,要全部分给 7 个小朋友,每个小朋友得到的糖果总数最少为 2个最多为 5 个,问有多少种不同的分法。糖果必须全部分完。

只要有其中一个小朋友在两种方案中分到的糖果不完全相同,这两种方案就算作不同的方案。

答案提交

这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 256M

总通过次数: 1358 | 总提交次数: 1521 | 通过率: 89.3%

难度: 简单 标签: 2023, 枚举, 省赛, DFS

代码分享:

cpp 复制代码
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
int ans=0;
void dfs(int a,int b,int id){
  if(id>7){
    if(a==0&&b==0)  ans++;
    return;
  }
  for(int i=0;i<=a;i++){
    for(int j=0;j<=b;j++){
      if((i+j)>=2 && (i+j)<=5)
      dfs(a-i,b-j,id+1);
    }
  }
}
int main()
{
  dfs(9,16,1);
  cout<<ans;
  // 请在此输入您的代码
  return 0;
}
相关推荐
ChoSeitaku2 分钟前
06_可变参数_递归_类和对象_封装
java·数据结构·算法
枕星而眠3 分钟前
C++ 核心语法精讲:auto / 模板 / 命名空间 / 动态内存 从用法到面试
开发语言·c++·面试
-To be number.wan7 分钟前
算法日记 | 动态规划(初级)
算法·动态规划
_深海凉_8 分钟前
LeetCode热题100-二叉搜索树中第 K 小的元素
算法·leetcode·职场和发展
图码8 分钟前
文本两端对齐算法详解:从LeetCode到实际应用
数据结构·图像处理·算法·leetcode·生成对抗网络·面试·职场和发展
yoyo_zzm9 分钟前
六大编程语言核心差异全解析
c语言·c++·spring boot·php
liu****10 分钟前
第16届国赛蓝桥杯大赛C/C++大学C组
c语言·数据结构·c++·算法·蓝桥杯
沈浩(种子思维作者)11 分钟前
物理的本质是数学,还是数学只是描述物理的方便之语?
人工智能·python·算法
yoyo_zzm13 分钟前
四大编程语言对比:C/C++/C#/PHP
c++·c#·php
程序员zgh19 分钟前
AUTOSAR CP 之 配置、开发流程、工具链 解析
c语言·开发语言·c++·系统架构·汽车