P1025 [NOIP2001 提高组] 数的划分

暴搜 剪枝

枚举固定的位置

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
using ll = long long;
const int N = 1e3+10;
int n,k;
int res;
void dfs(int last,int sum,int cur){
	
	if(cur==k){
		if(sum==n)res++;
		return;
	}
	
	for(int i=last;i+sum<=n;i++)
	 dfs(i,sum+i,cur+1);
}
int main()
{
	cin>>n>>k;
	dfs(1,0,0);
	cout<<res;
}
相关推荐
独自破碎E3 分钟前
【前缀和+哈希】LCR_011_连续数组
算法·哈希算法
一条大祥脚9 分钟前
26.1.26 扫描线+数论|因子反演+子序列计数|树套树优化最短路
数据结构·算法
m0_5613596712 分钟前
基于C++的机器学习库开发
开发语言·c++·算法
星空露珠19 分钟前
速算24点所有题库公式
开发语言·数据库·算法·游戏·lua
2401_8324027520 分钟前
C++中的类型擦除技术
开发语言·c++·算法
努力学习的小廉28 分钟前
我爱学算法之—— 递归回溯综合(二)
开发语言·算法
sheji526130 分钟前
JSP基于信息安全的读书网站79f9s--程序+源码+数据库+调试部署+开发环境
java·开发语言·数据库·算法
2301_7634724630 分钟前
C++网络编程(Boost.Asio)
开发语言·c++·算法
依依yyy35 分钟前
沪深300指数收益率波动性分析与预测——基于ARMA-GARCH模型
人工智能·算法·机器学习
hcnaisd21 小时前
深入理解C++内存模型
开发语言·c++·算法