热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

CF544C&51nod1086【限定个数的完全背包】

题意非常地晦涩难懂。有n个程序员总共必须要码m行代码,其中每个程序员平均每行会出现的bug有x[i]个,问在总bug不超过b个的情况下有多少种方案(不是按每行是谁码的来区分,是按最终每个人码了多少行来

题意非常地晦涩难懂。

有n个程序员总共必须要码m行代码,其中每个程序员平均每行会出现的bug有x[i]个,问在总bug不超过b个的情况下有多少种方案(不是按每行是谁码的来区分,是按最终每个人码了多少行来区分)?

dp(i,j,k):前i个程序员写了j行产生k个BUG的方案数。i省略。

#include 
#define ll long long
//#define mod 1000000007
using namespace std;
int x[505];
ll dp[505][505];
int main(){
int n,m,b,mod;
cin>>n>>m>>b>>mod;
for(int i=1;i<=n;++i)
cin>>x[i];
dp[0][0]=1;
for(int i=1;i<=n;++i){ //如果n和m的for循环位置换一换就变成是按每行是谁码的来区分
for(int j=1;j<=m;++j){
for(int k=b;k>=x[i];--k){
dp[j][k]=(dp[j][k]+dp[j-1][k-x[i]])%mod;
}
}
}
ll s=0;
for(int i=0;i<=b;++i)
s=(s+dp[m][i])%mod;
cout<return 0;
}

再看看另一道题。

有N种物品,每种物品的数量为C1,C2......Cn。从中任选若干件放在容量为W的背包里,每种物品的体积为W1,W2......Wn(Wi为整数),与之相对应的价值为P1,P2......Pn(Pi为整数)。求背包能够容纳的最大价值。

#include
#define ll long long
using namespace std;
ll w[105],p[105],c[105];
ll dp[500005];
int main(){
int n,m;
cin>>n>>m;
for(int i=1;i<=n;++i){
cin>>w[i]>>p[i]>>c[i];
}
for(int i=1;i<=n;++i){
for(int j=0;jfor(int k=m;k>=w[i];--k){
dp[k]=max(dp[k],dp[k-w[i]]+p[i]);
}
}
}
cout<return 0;
}

很可惜,这样写就要超时了。该加点什么黑科技吧。。。

解法挺奇妙的。我服。

把每种物品的个数以二进制枚举每一位选和不选,这样减少了很大的复杂度。

然而碰到一个二进制不是全1的个数怎么办?

刚才突然反应过来:假如不是全1,只要换成枚举小于等于它的全1二进制数,再单独处理零头。

#include  
#define ll long long
using namespace std;
ll w[105],p[105],c[105],d[105]; //c是小于等于它的全1二进制数,d是零头
ll dp[500005];
int main(){
int n,m;
cin>>n>>m;
for(int i=1;i<=n;++i){
cin>>w[i]>>p[i]>>c[i];
int u=0,s=0,p=c[i];
while(p>0){
if(p%2!=1)
u=1;
s++;
p/=2;
}
if(u==1)
s--;
if(u==1)
d[i]=c[i]-((1<c[i]=s;
}
for(int i=1;i<=n;++i){
for(int j=0;j for(int k=m;k>=w[i]*(1< dp[k]=max(dp[k],dp[k-w[i]*(1< }
}
// for(int j=1;j<=d[i];++j){
//for(int k=m;k>=w[i];--k){
//dp[k]=max(dp[k],dp[k-w[i]]+p[i]);
//}
//}
for(int k=m;k>=w[i]*d[i];--k){ //为什么零头都算上也能对?
dp[k]=max(dp[k],dp[k-w[i]*d[i]]+p[i]*d[i]);
}
}
cout< return 0;
}



推荐阅读
  • 理解存储器的层次结构有助于程序员优化程序性能,通过合理安排数据在不同层级的存储位置,提升CPU的数据访问速度。本文详细探讨了静态随机访问存储器(SRAM)和动态随机访问存储器(DRAM)的工作原理及其应用场景,并介绍了存储器模块中的数据存取过程及局部性原理。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 深入解析:阿里实战 SpringCloud 微服务架构与应用
    本文将详细介绍 SpringCloud 在微服务架构中的应用,涵盖入门、实战和案例分析。通过丰富的代码示例和实际项目经验,帮助读者全面掌握 SpringCloud 的核心技术和最佳实践。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 本文深入探讨了C++对象模型中的一些细节问题,特别是虚拟继承和析构函数的处理。通过具体代码示例和详细分析,揭示了书中某些观点的不足之处,并提供了更合理的解释。 ... [详细]
  • 随着网络安全威胁的不断演变,电子邮件系统成为攻击者频繁利用的目标。本文详细探讨了电子邮件系统中的常见漏洞及其潜在风险,并提供了专业的防护建议。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 深入理解Spring:Aware接口、异步编程与计划任务
    本文将带你深入了解Spring框架中的 Aware 接口、异步编程以及计划任务。通过具体示例和详细解释,帮助你掌握这些核心功能的实现原理和应用场景。 ... [详细]
  • TechStride 网站
    TechStride 成立于2014年初,致力于互联网前沿技术、产品创意及创业内容的聚合、搜索、学习与展示。我们旨在为互联网从业者提供更高效的新技术搜索、学习、分享和产品推广平台。 ... [详细]
  • 网易严选Java开发面试:MySQL索引深度解析
    本文详细记录了网易严选Java开发岗位的面试经验,特别针对MySQL索引相关的技术问题进行了深入探讨。通过本文,读者可以了解面试官常问的索引问题及其背后的原理。 ... [详细]
  • 前端开发:从底层到顶端的行业现象解析
    在编程领域,鄙视链现象屡见不鲜,从C语言到Java、.NET等,每个技术栈都有其独特地位。然而,前端开发者尽管常处于鄙视链底端,却在市场需求中备受青睐。本文深入探讨这一现象,并分析前端工程师如何在竞争激烈的市场中脱颖而出。 ... [详细]
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
  • PHP插件机制的实现方案解析
    本文深入探讨了PHP中插件机制的设计与实现,旨在分享一种可行的实现方式,并邀请读者共同讨论和优化。该方案不仅涵盖了插件机制的基本概念,还详细描述了如何在实际项目中应用。 ... [详细]
  • 分享一个简化版的Silverlight链接图项目:Link Map Simplified
    本文介绍了一个使用Silverlight开发的可视化工具,主要用于展示和操作复杂的实体关系图(Graph)。该工具在犯罪调查系统中得到了广泛应用,帮助用户直观地获取和理解相关信息。 ... [详细]
author-avatar
rlu1941950
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有