【蓝桥杯集训·每日一题】AcWing 3382. 整数拆分
创始人
2025-05-31 19:06:39
0

文章目录

  • 一、题目
    • 1、原题链接
    • 2、题目描述
  • 二、解题报告
    • 1、思路分析
    • 2、时间复杂度
    • 3、代码详解
  • 三、知识风暴
  • 背包DP

一、题目

1、原题链接

3382. 整数拆分

2、题目描述

一个整数总可以拆分为 2 的幂的和。

例如:7 可以拆分成

7=1+2+4,7=1+2+2+2,7=1+1+1+4,7=1+1+1+2+2,

7=1+1+1+1+1+2,7=1+1+1+1+1+1+1

共计 6 种不同拆分方式。

再比如:4 可以拆分成:4=4,4=1+1+1+1,4=2+2,4=1+1+2。

用 f(n) 表示 n 的不同拆分的种数,例如 f(7)=6。

要求编写程序,读入 n,输出 f(n)mod109

输入格式

一个整数 n。

输出格式

一个整数,表示 f(n)mod109

数据范围

1≤N≤106

输入样例

7

输出样例

6

二、解题报告

1、思路分析

我的思路
(1)想到了好像是完全背包问题,但是不会应用到题目中,所以直接暴力dfs了,只能过20%的数据。
(2)主要思路:先将不大于n的所有的2的次幂预处理出来,然后对这些数进行组合,每个数可以重复选,但是注意不要重复计算方案(每次从当前位置开始,选后面的数进行dfs即可避免,就是每次搜索只从当前数和其后面数开始搜索,不搜索其前面的数)。
y总思路

思路来源:y总讲解视频
y总yyds

(1)可以将该问题转化为类似完全背包问题。每个2的次幂为物品,其值为物品体积,而背包的容量为n
(2)dp[i][j]表示从前i个物品中选总体积恰好为j的方案的总数。
(3)按照第i个物品选几个对dp[i][j]进行分类,则类似完全背包问题可以得到转移方程 dp[i][j]=dp[i-1][j]+dp[i][j-v[i]]
(4)因为每次转移时只需要用到本层其左边和上一层当前位置的值,所以可以利用 滚动数组,从前小到达枚举背包体积进行空间优化:dp[j]=dp[j]+dp[j-v[i]]

2、时间复杂度

我的思路时间复杂度O(nlogn+1)
y总思路时间复杂度O(nm)(n为物品数,m为背包体积)

3、代码详解

我的思路

#include 
using namespace std;
const int N=110,mod=1e9;
int v[N];   //记录每个2的次幂的值
int n,cnt,ans;
//搜索方案数,target为目标值,sum为当前已经搜索的数的总和,st为当前应该开始搜索的位置
void dfs(int target,int sum,int st){//如果当前总和已经大于目标值,继续搜索一定找不到一组方案,直接回溯即可if(sum>target) return ;//如果当前总和正好等于目标值,说明是一种方案,使方案数+1,然后回溯if(target==sum){ans++;return ;}//每次从当前位置(包括当前位置)向后搜索,注意剪枝:当前总和如果加上枚举的数之后已经大于target就没必要深搜了for(int i=st;idfs(target,sum+v[i],i);}
}
int main(){cin>>n;//预处理出每个2的次幂的值for(int i=1;i<=n;i*=2) v[cnt++]=i;dfs(n,0,0);cout<

y总思路

#include 
using namespace std;
const int N=1000010,mod=1e9;
int dp[N];
int n;
int main(){cin>>n;dp[0]=1;     //体积为0的方案数只有一种for(int i=1;i<=n;i*=2){    //枚举物品for(int j=i;j<=n;j++){ //枚举背包体积dp[j]=(dp[j]+dp[j-i])%mod;  //转移方程}}cout<

三、知识风暴

背包DP

  • 0-1背包问题:参考我的这篇博客
  • 完全背包问题

相关内容

热门资讯

马斯克起诉 OpenAI 和微... 马斯克宣布起诉 OpenAI 与微软,索赔最高 1340 亿美元 1 月 17 日消息,当地时间周五...
IPO雷达|“墨水平板商”文石... 深圳商报·读创客户端记者 梁佳彤 1月16日,据港交所官网,以“墨水平板”为主打产品的广州文石信息科...
原创 片... 片仔癀终于要回到最后一次涨价之前的价格了!在2023年5月5日,片仔癀最后提了一次价,从590提到了...
原创 创... 在火锅行业竞争愈发激烈的当下,餐饮巨头海底捞迎来了一次重大的人事与战略调整。 2026年1月13日,...
原创 黄... 本文黄金、白银等产品行情分析,以国际报价为基准;国际和国内价格换算方法,国际价格×汇率÷31.1≈国...
IPO雷达|拓斯达递表前夕收警... 日前,广东拓斯达科技股份有限公司(简称:“拓斯达”)递交招股书,准备在港交所上市,华泰国际为独家保荐...
原创 中... 经历了长达十五个月的艰苦博弈,布鲁塞尔方面终于迎来了所谓的和解时刻。但几乎没有过几天,欧盟就急不可耐...
B站百大UP主名单出炉,优质内... 1月18日中午,哔哩哔哩年度百大UP主名单揭晓。这届百大UP主人均创作时长近7年,累计创作超4.9万...
原创 2... 中国经济版图正迎来新一轮震撼洗牌!根据最新预测数据,2025年全国GDP20强城市座次已定,万亿俱乐...
睿云联创冲刺港股:9个月营收2... 雷递网 雷建平 1月18日 厦门睿云联创新科技股份有限公司(简称:“睿云联创”)日前递交招股书,准备...
美锦能源两年亏损近20亿元,山... 来源:华夏时报 1月15日晚间,山西美锦能源股份有限公司(下称“美锦能源”,000723.SZ)发...
IXDC专访 | 森马服饰营销... 随着 AI 技术在电商视觉设计领域的深度赋能,如何依托用户精细化洞察让视觉设计更好适配线上消费决策需...
原创 存... 当地时间1月16日,在与中国台湾达成关税协议之后,美国商务部长霍华德·卢特尼克警告称,包括存储芯片制...
睿远基金创始人陈光明向上海交大... 【大河财立方消息】据上海交大,该校1996届本科、1999届硕士校友、学校校董、睿远基金创始人陈光明...
马斯克称特斯拉AI5接近设计完... IT之家 1 月 18 日消息,埃隆 · 马斯克昨天在 X 平台表示,特斯拉 AI5 芯片已接近设计...
【数智周报】 谷歌DeepMi... 数智周报将整合本周最重要的企业级服务、云计算、大数据领域的前沿趋势、重磅政策及行研报告。】 观点 科...
原创 伤... 伤害性极大!侮辱性更强!这就是赤裸裸的现实! 2015年,大疆收入59.8亿,净利润14.2亿。 ...
原创 美... 战火一烧,门槛就高了。 不是谁都能随便进场玩的。 中美之间那场从2018年就开始的贸易摩擦,早就不是...
宏微科技:公司已累计拥有超过1... 证券日报网讯 1月16日,宏微科技在互动平台回答投资者提问时表示,公司始终将自主创新作为发展核心,核...