动态规划—(背包问题)

简介: 动态规划—(背包问题)

动态规划与其他算法比较,大大减少了计算量,丰富了计算的结果,最适合解决最优解问题。今天讲的是背包问题。

1、0-1背包:

简介:有n件物品,总空间是w,前i件的容量是w[i],前i件的价值是v[i],那么所获取的最大容量是dp[w].

代码如下:

#include<stdio.h>
#include<string.h>
int f[201000];
int w[210000];
int v[210000];
int max(int n,int m)
{
  if(n>m)
    return n;
  else
    return m;
}
int main()
{
    int n,m;
    int i,j;
    while(~scanf("%d%d",&n,&m))
    {
      memset(f,0,sizeof(f));
      for(i=1;i<=n;i++)
          scanf("%d%d",&w[i],&v[i]);
      for(i=1;i<=n;i++)
          for(j=m;j>=w[i];j--)
          {
             int s=f[j-w[i]]+v[i];
             f[j]=max(f[j],s);
          }
      printf("%d\n",f[m]);
  }
    return 0;
}

2、完全背包:

简介:完全背包是有n种物品,总空间为w,每种的物品的件数是无限个,已知每种物品的容量为w[i],价值为v[i],如何满足最大价值。

代码如下:

#include <iostream>
#include <algorithm>
using namespace std;
int a[600],b[600],dp[1000005];
int main()
{
    int t,x,y,n;
    cin>>t;
    while(t--){
        int w;
        cin>>w;   //背包容量
        cin>>n;
        for(int i=0;i<n;i++)
            cin>>b[i]>>a[i];
        for(int i=0;i<=w;i++)  //初始化分两种情况:1、如果背包要求正好装满则初始化 f[0] = 0,  f[i]=INF;2、如果不需要正好装满 f[0~w] = 0; 
            dp[i]=0;
        for(int i=0;i<n;i++)
           for(int j=b[i];j<=w;j++)//j表示背包容量 
                dp[j]=max(dp[j],dp[j-b[i]]+a[i]);
   // for(int i=1;i<=w;i++)
        cout<<dp[w]<<endl;
    }
    return 0;
}

3、多重背包:

简介:多重背包就是0-1背包的扩展,0-1背包每一种物品一共有一件,多重背包每一种可能有多件,如一共有n种物品,每种物品的件数是bag[i],总空间是w,每一件容量是w[i],每一件价值是v[i].

代码如下:

#include<iostream>
#include<string.h>
#include <algorithm>
int v[1000],w[1000],c[1000],dp[1000];
using namespace std;
int main()
{
  int T;
  cin>>T;
  while(T--)
  {
    memset(dp,0,sizeof(dp));
    int n,m;
    cin>>n>>m;
    for(int i=1;i<=m;i++)
      cin>>v[i]>>w[i]>>c[i];
    for(int i=1;i<=m;i++)
      for(int k=1;k<=c[i];k++)
        for(int j=n;j>=v[i];j--)
          dp[j]=max(dp[j],dp[j-v[i]]+w[i]);
    cout<<dp[n]<<endl;
  }
  return 0;
}
相关文章
|
安全 测试技术 数据库
OWASP ZAP 工具简介
OWASP ZAP 工具简介
914 0
OWASP ZAP 工具简介
|
Rust 算法 数据安全/隐私保护
【密码学】一文读懂XTEA加密
本篇文章,我们来看一下上一次讲过的TEA加密算法的一个升级版XTEA, 相比于TEA, XTEA的安全性显然是更高的,其中的过程要比TEA稍微复杂一点点。
1634 0
【密码学】一文读懂XTEA加密
|
自动驾驶 物联网 5G
深入探索5G网络中的网络切片技术及其应用场景
深入探索5G网络中的网络切片技术及其应用场景
3777 3
|
存储 自然语言处理 算法
“无”中生有:基于知识增强的RAG优化实践
本文作者基于自身在RAG技术领域长达半年的实践经验,分享了从初识RAG的潜力到面对实际应用挑战的心路历程,以及如何通过一系列优化措施逐步解决这些挑战的过程。
1313 20
“无”中生有:基于知识增强的RAG优化实践
|
Web App开发 数据可视化 搜索推荐
博士科研最好用的科研绘图工具有哪些?
该博客介绍了几种博士科研中最好用的科研绘图工具,包括ChiPlot、Veusz、Echarts、MeedPeer和Python可视化库,并提供了它们的优缺点分析。
919 2
博士科研最好用的科研绘图工具有哪些?
|
存储 数据采集 数据挖掘
Polars实践(4):阿里天池——淘宝用户购物行为分析
Polars实践(4):阿里天池——淘宝用户购物行为分析
570 1
|
SQL 数据采集 关系型数据库
在 Postgres 中使用 CTE
【8月更文挑战第11天】
418 0
在 Postgres 中使用 CTE
|
Java 物联网 应用服务中间件
Socket网络编程中的常见应用场景与实例分析
Socket网络编程中的常见应用场景与实例分析
|
网络协议
DHCP服务详解
DHCP服务详解
990 0
|
自然语言处理 Java
ElasticSearch 实现分词全文检索 - match、match_all、multimatch查询
ElasticSearch 实现分词全文检索 - match、match_all、multimatch查询
1333 0