蓝桥杯真题:砝码称重「建议收藏」

蓝桥杯动态规划

大家好,又见面了,我是你们的朋友全栈君。

蓝桥杯真题:砝码称重「建议收藏」

样例输入

3
1 4 6

样例输出

10

蓝桥杯真题:砝码称重「建议收藏」

思路:

这题是不是看起来很简单,我们的目标其实是求各个数只进行加减操作可以获得多少个数(包括操作的数本身),但是我们不能把所有数字放在一起想。

我们用dp的思路去想,首先放进来一个砝码,相应的重量是可以称出来的,再放下一个砝码,那么这是下一层dp:上一层的都可以称出来,加上本身对应的重量可以称出来,我们这个重量和上一层所有可以称出来的重量进行加减,不就是这一层可能获得的新的重量情况么

代码如下所示:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N=101,M=100001;
int w[N];
int dp[N][M];
int main()
{
  // 请在此输入您的代码
  int number;
  LL sum=0;
  scanf("%d",&number);
  for(int i=0;i<number;++i)
  {
    scanf("%d",&w[i]);
    sum+=w[i];
  }
  dp[0][w[0]]=1;

  for(int i=1;i<number;++i)
  {
    int now_weight=w[i];
    for(int j=1;j<=sum;++j)
    {
      dp[i][j]=dp[i-1][j];
    }
    dp[i][now_weight]=1;
    for(int j=1;j<=sum;++j)
    {
      if(dp[i-1][j]==1)
      {
        dp[i][now_weight+j]=1;
        dp[i][abs(now_weight-j)]=1;
      }
    }
  }
  int ans=0;
  for(int i=1;i<=sum;++i)
  {
    if(dp[number-1][i]==1)ans++;
  }
  cout<<ans;
  return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128855.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java中beanutils_java bean

    java中beanutils_java beanBeanUtils<!–原型设计模式:复制属性–> Maven包<dependency><groupId>commons-beanutils</groupId><artifactId>commons-beanutils</artifactId><version>1.9.3</version>

    2025年9月12日
    4
  • linux 网口_网络管理员网址

    linux 网口_网络管理员网址Linux12:网络管理文章目录一.网络接口名称规则1.认识网卡2.修改网卡配置文件3.主机名4.网络测试工具一.网络接口名称规则计算机与外界通信的前提是:有网卡(网络适配器NAT)注意:虚拟机的总内存,不能超过真机服务器和客户机:谁提供服务,谁就是服务器1.认识网卡#ls /etc/sysconfig/network-scripts/补充:网络管理器NetworkManager,动态网络的控制器与配置系统,它用于当网络设备可用时保持设备和连接开启并激活查看该服务的运行状况:#

    2022年8月9日
    5
  • web是什么?_怎么进入web界面

    web是什么?_怎么进入web界面我也是从接触Web这个词开始就一直搞不清和Internet之间是什么关系。说说我理解的Web,可能很多地方不准确.Web就是在Http协议基础之上,利用浏览器进行访问的网站.WebPage指

    2022年8月2日
    16
  • Pycharm2021.5 激活码获取的方式及使用(最新序列号破解)

    Pycharm2021.5 激活码获取的方式及使用(最新序列号破解),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月19日
    74
  • 使用BCGControlBar界面库美化MFC界面的详细过程

    使用BCGControlBar界面库美化MFC界面的详细过程系统环境:Windows7软件环境:VisualStudio2013本次目的:实现MFC对话框换肤下载安装BCGControlBar25激活成功教程版安装完成自动弹出编译库文件的对话框,选择需要的进行编译,需要一段时间,等候,完成打开vs2013首先使用BCGPAppWizard建立工程:Applicationtype:Dialog

    2022年10月8日
    1
  • C++多线程并发(五)—原子操作与无锁编程

    C++多线程并发(五)—原子操作与无锁编程一、何为原子操作前面介绍了多线程间是通过互斥锁与条件变量来保证共享数据的同步的,互斥锁主要是针对过程加锁来实现对共享资源的排他性访问。很多时候,对共享资源的访问主要是对某一数据结构的读写操作,如果数据结构本身就带有排他性访问的特性,也就相当于该数据结构自带一个细粒度的锁,对该数据结构的并发访问就能更加简单高效,这就是C++11提供的原子数据类型<atomic>。下面解释两个概念:…

    2022年6月8日
    57

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号