洛谷 P1025 [NOIP2001 提高组] 数的划分

 

最简单的优化是从小到大去枚举,这样可以防止重复计数。

可行性剪枝:每次枚举到 i 时判断,如果此后的数都>= i 他们的和是否会过大(把过大的分支剪掉) 

pass:优化方案不唯一

由于数据原因,sum+i<=n这个判定条件也可以过。

 

#include<cstdio>
#include<iostream>
using namespace std; 
int n,k,cnt;
//cnt表示方案数 
//last表示上一个数的大小,枚举时从小到大枚举强制顺序 
//sum表示之前数的和,now表示当前已经枚举了几个数字 
void dfs(int last,int sum,int now) 
{
    if(now==k)
    {
        if(sum==n) cnt++;
        return;
    }
   // for(int i=last;i<=n;i++) //不优化就会TLE 
    for(int i=last;sum+i*(k-now)<=n;i++)//小剪枝,只用枚举到sum+i*(k-now)<=n为止
        dfs(i,sum+i,now+1);
}

int main()
{
    scanf("%d%d",&n,&k);
    dfs(1,0,0);
    printf("%d",cnt);
}

 

posted @   浪矢-CL  阅读(39)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App
历史上的今天:
2017-07-24 数字(number)
2017-07-24 寻找最美的你(select)
2017-07-24 木棍
2017-07-24 lowbit
点击右上角即可分享
微信分享提示