【dp】砝码称重模型(选或不选)

目录

蓝桥杯 砝码称重

牛客 我不是大富翁 

 abc 344 D

cf div3 933 D 


蓝桥杯 砝码称重

题目链接: https://www.lanqiao.cn/problems/1447/learning/?page=1&first_category_id=1&sort=students_count&category_id=3&name=%E7%A0%9D%E7%A0%81%E7%A7%B0%E9%87%8D 

思想:

不选  = j

放右边 = j + a[i]

放左边 = abs (j - a[i])

代码:

#include<bits/stdc++.h>
using namespace std;#define int long longconst int N = 2e5+5;int n,a[N];
int dp[105][N];signed main(){ios::sync_with_stdio(false);cin.tie(nullptr);cin>>n;for(int i=1;i<=n;i++){cin>>a[i];}dp[0][0]=1;for(int i=1;i<=n;i++){for(int j=0;j<=1e5;j++){if(dp[i-1][j]){dp[i][j]=1;  //不选dp[i][j+a[i]]=1;  //放右边dp[i][abs(j-a[i])]=1;  //放左边}}}int ans=0;for(int i=1;i<=1e5;i++){if(dp[n][i]) ans++;}cout<<ans<<"\n";return 0;	}

牛客 我不是大富翁 

题目链接 :https://ac.nowcoder.com/acm/contest/75771/D

思想:开二维bool 数组,判断第 i 次操作 是否可能位于 j 的位置

代码:

#include<bits/stdc++.h>
using namespace std;#define int long longconst int N = 5001;int n,m;
int a[N];
bool dp[N][N]; //i次操作是否可能位于j的位置signed main(){ios::sync_with_stdio(false);cin.tie(nullptr);cin>>n>>m;for(int i=1;i<=m;i++){cin>>a[i];a[i]%=n;}dp[0][0]=1;for(int i=1;i<=m;i++){for(int j=0;j<n;j++){if(dp[i-1][(n+j-a[i])%n]||dp[i-1][(j+a[i])%n]){dp[i][j]=1;}else dp[i][j]=0;}}if(dp[m][0]) cout<<"YES\n";else cout<<"NO\n";return 0;	}

 abc 344 D

题目链接:https://atcoder.jp/contests/abc344/tasks/abc344_d

思想:一维数组表示当前长度的最小次数

?为什么要开dp2

代码:

#include<bits/stdc++.h>
using namespace std;#define int long longconst int N = 1010;string s,t;
int n,m;
int f[N][N];  //表示在前i项中 此时长度为j 的最小次数signed main(){ios::sync_with_stdio(false);cin.tie(nullptr);cin>>s;vector<int> dp(s.size()+1,1e15);dp[0]=0;cin>>n;for(int i=1;i<=n;i++){vector<int> dp2=dp;cin>>m;while(m--){cin>>t;for(int j=0;j<s.size();j++){if(j+t.size()<=s.size()&&s.substr(j,t.size())==t){dp2[j+(int)t.size()]=min(dp2[j+(int)t.size()],dp[j]+1);}}}dp=dp2;}if(dp.back()==1e15){cout<<"-1\n";}else cout<<dp.back()<<"\n";return 0;	}

cf div3 933 D 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/745416.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu20.04配置C/C++环境

1. C/C++ IDE 安装Clion Nova和VsCode 2. 编译器 2.1 g++ 当程序比较小时,安装g++编译器进行编译,常用命令如下: // 安装g++ sudo apt-get install g++ // 默认生成a.out的可执行文件 g++ main.cpp // 生成其他名字的可执行文件 g++ main.cpp -o exe_name2.2 cmake 当…

【leetcode题解C++】146. LRU缓存

请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类&#xff1a; LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中&#xff0c;则返回关键字的值&#xff0c;否则返回 -…

Jmeter扩展开发--自定义java取样器

简介 jmeter内置了包括&#xff1a;http、https、tcp等各种协议的支持&#xff0c;通常情况只需要做简单的参数配置即可使用。但在某些特殊情况下&#xff0c;还是希望能做自定义压测处理&#xff0c;此时就涉及Jmeter的扩展开发自定义Java取样器&#xff0c;如下图所示&#…

基于centos7的k8s最新版v1.29.2安装教程

k8s概述 Kubernetes 是一个可移植、可扩展的开源平台&#xff0c;用于管理容器化的工作负载和服务&#xff0c;可促进声明式配置和自动化。 Kubernetes 拥有一个庞大且快速增长的生态&#xff0c;其服务、支持和工具的使用范围相当广泛。 Kubernetes 这个名字源于希腊语&…

分布式微服务 - 4.服务增强 - 1.概念

分布式微服务 - 4.服务增强 - 1.概念 项目示例&#xff1a; 无 内容提要&#xff1a; 配置中心、框架 文档&#xff1a; 无 配置中心 随着需求的不断开发实现&#xff0c;系统逐渐庞大&#xff0c;微服务逐渐增多&#xff0c;系统涉及到的配置信息不断增多&#xff0c;…

Github主页设置贪吃蛇详细教程

先看最终实现结果&#xff1a; 有条贪吃蛇放在主页还是蛮酷的哈哈哈。接下来我来讲一讲怎么在Github主页添加一条贪吃蛇。 首先要修改自己的Github的主页&#xff0c;我们得有一个特殊的仓库——这个仓库必须与你的Github用户名保持一致&#xff0c;并且需要公开&#xff0c…

力扣日记3.14-【贪心算法篇】376. 摆动序列

力扣日记&#xff1a;【贪心算法篇】376. 摆动序列 日期&#xff1a;2024.3.14 参考&#xff1a;代码随想录、力扣 376. 摆动序列 题目描述 难度&#xff1a;中等 如果连续数字之间的差严格地在正数和负数之间交替&#xff0c;则数字序列称为 摆动序列 。第一个差&#xff08;…

【JavaEE】网络原理-HTTPS

网络原理-HTTPS 1. HTTPS是什么 HTTPS是在应用层上的协议&#xff0c; 基于HTTP进行加密 HTTP协议内容都是按照文本内容进行明文传输&#xff0c;容易使得内容被“劫持”。 十年前&#xff0c;经常有下载链接被劫持&#xff0c;就会产生下载图片和下载链接不是一个产品的现象…

python毕业设计基于flask应急救援调度系统django

此系统设计主要采用的是python语言来进行开发&#xff0c;采用flask框架技术&#xff0c;框架分为三层&#xff0c;分别是控制层Controller&#xff0c;业务处理层Service&#xff0c;持久层dao&#xff0c;能够采用多层次管理开发&#xff0c;对于各个模块设计制作有一定的安全…

docker日志在哪看?怎么在Linux服务器中查看日志

Docker 日志主要分为两类&#xff0c;一类是Docker 引擎日志&#xff0c;另一类是容器日志。具体如下&#xff1a; Docker 引擎日志&#xff1a;这些日志记录了 Docker 引擎本身的操作信息&#xff0c;其位置依赖于使用的操作系统。例如&#xff0c;在 Ubuntu 14.04 中&#x…

Tengine 的xquic,如何适配四层负载的udp健康检查?

为什么要适配udp健康检查&#xff1f; Tengine通过xquic实现HTTP3协议&#xff0c;不同于HTTP2和HTTP1.1以及之前的HTTP协议&#xff0c;HTTP3最大的不同就是其传输层协议由TCP改成了基于UDP实现的QUIC协议。QUIC 协议实现在用户态&#xff0c;建立在内核态的 UDP 的基础之上&…

【投稿优惠-EI稳定检索】2024年图像处理与机械系统工程国际学术会议 (ICIPMSE 2024)

【投稿优惠-EI稳定检索】2024年图像处理与机械系统工程国际学术会议 (ICIPMSE 2024) 大会主题: (主题包括但不限于, 更多主题请咨询会务组苏老师) 图像处理 基于图像的渲染 计算机视觉 可视化分析 模式识别 3D打印 渲染和动画 渲染技术 电脑动画 基于草图的建模 机械…

IT领域的未来发展趋势与挑战

IT行业作为当今世界最具活力和创新性的领域之一&#xff0c;持续地塑造着我们的生活和工作方式。在未来&#xff0c;IT领域将继续迎来许多重要的发展趋势和挑战&#xff0c;这些趋势将引领着技术的发展方向&#xff0c;而挑战则需要我们找到有效的解决方案。 1. 人工智能&…

苹果Find My App用处多多,产品认准伦茨科技ST17H6x芯片

苹果发布AirTag发布以来&#xff0c;大家都更加注重物品的防丢&#xff0c;苹果的 Find My 就可以查找 iPhone、Mac、AirPods、Apple Watch&#xff0c;如今的Find My已经不单单可以查找苹果的设备&#xff0c;随着第三方设备的加入&#xff0c;将丰富Find My Network的版图。产…

Unity Timeline学习笔记(2) - PlayableTrack

PlayableTrack 是可自定义播放的轨道。我们可以通过进入轨道后调用自己的函数方法&#xff0c;使用起来也是比较顺手的。 添加轨道 我们点击加号添加 这样就有一个空轨道了&#xff0c;然后我们创建两个测试脚本。 添加脚本 分别是Playable Behaviour和PlayableAsset脚本。…

unity报错出现Asset database transaction committed twice!

错误描述&#xff1a; 运行时报错 Assertion failed on expression: ‘m_ErrorCode MDB_MAP_RESIZED || !HasAbortingErrors()’Asset database transaction committed twice!Assertion failed on expression: ‘errors MDB_SUCCESS || errors MDB_NOTFOUND’ 解决办法&…

MySQL:概念简章

1.SQL通用语法 SQL单行、多行书写&#xff0c;以分号结尾SQL可以以空格有缩进增加代码可读性SQL语句不区分大小写 2.SQL语句分类 2.1 DDL&#xff08;数据定义语言&#xff09; 用于数据库、数据表、字段的定义的语言 create by 表名 &#xff08;表里有什么字段&#xff09;…

Hive中的CONCAT、CONCAT_WS与COLLECT_SET函数

1.CONCAT与CONCAT_WS函数 1.1 CONCAT函数 -- concat(str1, str2, ... strN) - returns the concatenation of str1, str2, ... strN or concat(bin1, bin2, ... binN) - returns the concatenation of bytes in binary data bin1, bin2, ... binN Returns NULL if any argum…

幼儿园管理系统|基于springboot框架+ Mysql+Java+Tomcat的幼儿园管理系统设计与实现(可运行源码+数据库+设计文档+部署说明)

推荐阅读100套最新项目 最新ssmjava项目文档视频演示可运行源码分享 最新jspjava项目文档视频演示可运行源码分享 最新Spring Boot项目文档视频演示可运行源码分享 目录 用户功能模块 管理员功能登录前台功能效果图 教师功能模块 系统功能设计 数据库E-R图设计 lunwen参…

项目安全保证措施word

软件系统做项目安全保证措施的原因有以下几点&#xff1a; 保护数据安全&#xff1a;通过安全措施可以保护数据不被非法获取、篡改或损坏。 保障系统稳定&#xff1a;安全措施可以减少系统受到的威胁&#xff0c;确保系统的稳定运行。 符合法律法规&#xff1a;为了遵守国家和地…