蓝桥杯备赛-DFS-数的划分

题目描述

将整数 n 分成 k 份,且每份不能为空,任意两个方案不相同(不考虑顺序)。

例如:n=7,k=3,下面三种分法被认为是相同的。

1,1,5;

1,5,1;

5,1,1.

问有多少种不同的分法。

输入格式

n,k (6<n≤200,2≤k≤6)

输出格式

1 个整数,即不同的分法。

输入输出样例

输入 #1复制

复制代码
7 3

输出 #1复制

复制代码
4

说明/提示

四种分法为:

1,1,5;

1,2,4;

1,3,3;

2,2,3.

cpp 复制代码
#include<iostream>
#include<vector>
int n, k;
int ans=0;
int start=1;//记录前一个数字,保证数列是递增的
int sum = 0;
using namespace std;
void dfs(int x) {
	if (x == k+1) {
		if (sum == n) {
			ans++;
		}//要进行判断,比如n为7时,1,1,1就是不满足的
		return;
	}
	for (int i = start; i <= n-sum; i++) {//i <= n-sum可以进行剪枝,数列是递增的,后面的数字是越来越大的,比如n为7时,1,4再往后面循环1,4,4,和是9超过了7,1,4,5更不用说,所以是会被剪掉的
		start = i;
		sum += i;
		dfs(x + 1);
		sum -= i;//记得返回,回溯后上一层还要继续用
	}
}
int main() {
	cin >> n >> k;
	dfs(1);
	cout << ans;
	return 0;
}
相关推荐
GUIQU.19 分钟前
【每日一题 | 2025年5.5 ~ 5.11】搜索相关题
算法·每日一题·坚持
双叶83619 分钟前
(C语言)超市管理系统(测试版)(指针)(数据结构)(二进制文件读写)
c语言·开发语言·数据结构·c++
不知名小菜鸡.19 分钟前
记录算法笔记(2025.5.13)二叉树的最大深度
笔记·算法
真的想上岸啊1 小时前
c语言第一个小游戏:贪吃蛇小游戏05
c语言·算法·链表
格林威1 小时前
Baumer工业相机堡盟工业相机的工业视觉是否可以在室外可以做视觉检测项目
c++·人工智能·数码相机·计算机视觉·视觉检测
追烽少年x1 小时前
C++11异步编程 --- async
c++
元亓亓亓1 小时前
LeetCode热题100--206.反转链表--简单
算法·leetcode·链表
诚丞成1 小时前
BFS算法篇——从晨曦到星辰,BFS算法在多源最短路径问题中的诗意航行(上)
java·算法·宽度优先
hongjianMa1 小时前
2024睿抗编程赛国赛-题解
算法·深度优先·图论·caip
czy87874752 小时前
两种常见的C语言实现64位无符号整数乘以64位无符号整数的实现方法
c语言·算法