博客
关于我
4119:复杂的整数划分问题
阅读量:266 次
发布时间:2019-03-01

本文共 1316 字,大约阅读时间需要 4 分钟。

#include 
using namespace std;int slvK(int n,int k){ auto dp=vector
>(n+1,vector
(n+1,0)); //dp[i][j]:将整数i划分为j个整数之和的划分数 dp[0][0]=1; for(int i=1;i<=n;++i){ for(int j=1;j<=i;++j){ dp[i][j]=dp[i-j][j]+dp[i-1][j-1]; //dp[i-j][j]:i的划分中不包含1 //dp[i-1][j-1]:划分包含1 } } return dp[n][k];}int slvD(int n){ auto dp=vector
>(n+1,vector
(n+1,0)); //dp[i][j]:将整数i划分为最大数为j的划分数 dp[0]=vector
(n+1,1); for(int i=1;i<=n;++i){ for(int j=1;j<=n;++j){ if(j>i) dp[i][j]=dp[i][i]; else dp[i][j]=dp[i-j][j-1]+dp[i][j-1]; //dp[i-j][j-1]:i里包含j //dp[i][j-1]:不包含j } } return dp[n][n];}int slvO(int n){ auto dp=vector
>(n+1,vector
(n+1,0)); //dp[i][j]:将整数i划分为最大数为j的划分数 for(int i=1;i<=n;++i){ dp[i][1]=dp[0][i]=1; } for(int i=1;i<=n;++i){ for(int j=1;j<=n;++j){ if(j%2){ //j为奇数 if(j>i) dp[i][j]=dp[i][i]; else dp[i][j]=dp[i-j][j]+dp[i][j-1]; } else dp[i][j]=dp[i][j-1]; } } return dp[n][n];}int main(){ int n,k; while(~scanf("%d %d",&n,&k)){ printf("%d\n",slvK(n,k)); printf("%d\n",slvD(n)); printf("%d\n",slvO(n)); } return 0;}

参考:

转载地址:http://pybx.baihongyu.com/

你可能感兴趣的文章
MySQL
查看>>
mysql
查看>>
MTK Android 如何获取系统权限
查看>>
MySQL - 4种基本索引、聚簇索引和非聚索引、索引失效情况、SQL 优化
查看>>
MySQL - ERROR 1406
查看>>
mysql - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
MTTR、MTBF、MTTF的大白话理解
查看>>
mt_rand
查看>>
mysql -存储过程
查看>>
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>
MySQL 8.0开始Group by不再排序
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>