动态规划(题目提升)

 [NOIP2012 普及组] 摆花

方法一:记忆化搜索

何为记忆化搜素:就是使用递归函数对每次得到的结果进行保存,下次遇到就直接输出即可

那么这个题目使用递归(DFS)是怎样的?
首先我们需要搞清楚几个坑点:1.不是所有的花都要取到,只要我们取到的花的数量满足题目给的要求就可以了。  2.我们使用递归函数的时候需要使用一个变量step来代表我们所选择的花的种类,然后还需要一个变量来代表我们已经选的花的数量即可,先用void类型来写一遍这个函数

#include<iostream>
using namespace std;
int a[100000];
int n,m;
int ans=0;
void dfs(int step,int sum)
{if(step>n){if(sum==m){ans++;return ;}return ;}for(int i=0;i<=a[step];i++){dfs(step+1,sum+i);}return ;
}
int main()
{cin>>n>>m;for(int i=1;i<=n;i++)cin>>a[i];dfs(1,0);cout<<ans<<endl;return 0;
}

使用void类型来书写的函数的好处就是方便理解,但是这样就是用不了记忆化搜索

所以再用int类型来书写一遍dfs函数

#include<iostream>
using namespace std;
const int N=10000,mod = 1000007;
int a[100000];
int n,m;
int vis[N][N];
int dfs(int step,int sum)
{if(sum>m)return 0;if(sum==m)//终止条件只能是这一个,后面的花可以没有被种return 1;if(step==n+1)//如果种类已经查过了最大种类,那么就不能继续搜索return 0;//if(vis[step][sum])//如果已经查过了,那么就不需要查了直接返回//return vis[step][sum];int ans=0;//for(int i=0;i<=a[step];i++){ans=(dfs(step+1,sum+i)+ans)%mod;}//vis[step][sum]=ans;return ans;
}
int main()
{cin>>n>>m;for(int i=1;i<=n;i++)cin>>a[i];cout<<dfs(1,0)<<endl;return 0;
}

记忆化就是在其中加上数组用于保存数据

#include<iostream>
using namespace std;
const int N=10000,mod = 1000007;
int a[100000];
int n,m;
int vis[N][N];
int dfs(int step,int sum)
{if(sum>m)return 0;if(sum==m)//终止条件只能是这一个,后面的花可以没有被种return 1;if(step==n+1)//如果种类已经查过了最大种类,那么就不能继续搜索return 0;if(vis[step][sum])//如果已经查过了,那么就不需要查了直接返回return vis[step][sum];int ans=0;//这个ans变量一定要放在dfs函数内部for(int i=0;i<=a[step];i++){ans=(dfs(step+1,sum+i)+ans)%mod;}vis[step][sum]=ans;return ans;
}
int main()
{cin>>n>>m;for(int i=1;i<=n;i++)cin>>a[i];cout<<dfs(1,0)<<endl;return 0;
}

方法二:动态规划

想了很久 没想出来

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

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

相关文章

C/C++语言文字小游戏(荒岛求生)

游戏背景 玩家在荒岛上&#xff0c;需要寻找食物、水源、避难所等资源来生存。 玩家需要避免危险&#xff0c;如野兽、植物、天气等&#xff0c;否则会失去血量或生命。 玩家可以在荒岛上遇到其他生存者&#xff0c;可以选择合作或对抗。 游戏目标是生存一定时间或找到生存的出…

Javaweb之SpringBootWeb案例之 Bean管理的第三方Bean的详细解析

2.3 第三方Bean 学习完bean的获取、bean的作用域之后&#xff0c;接下来我们再来学习第三方bean的配置。 之前我们所配置的bean&#xff0c;像controller、service&#xff0c;dao三层体系下编写的类&#xff0c;这些类都是我们在项目当中自己定义的类(自定义类)。当我们要声…

将任何网页变成桌面应用,全平台支持 | 开源日报 No.184

tw93/Pake Stars: 20.9k License: MIT Pake 是利用 Rust 轻松构建轻量级多端桌面应用的工具。 与 Electron 包大小相比几乎小了 20 倍&#xff08;约 5M&#xff01;&#xff09;使用 Rust Tauri&#xff0c;Pake 比基于 JS 的框架更轻量和更快内置功能包括快捷方式传递、沉浸…

常见设计模式之单例模式

单例模式 单例模式是一种常用的软件设计模式&#xff0c;主要目的是确保一个类在整个应用程序生命周期中只有一个实例&#xff0c;并提供一个全局访问点以获取该实例。 单例模式分为几种不同的实现方式&#xff0c;包括懒汉模式和饿汉模式。每种方式都有其特点和适用场景。例如…

vue或者uniapp修改数据后页面不重新渲染

1.数据是对象 通常是某个渲染的数组改变了层级较深的数据导致页面没有实时渲染 this.itemsJSON.parse(JSON.stringify(this.items)); 2.数据是数组 this.$set 方法&#xff0c;可以显式地告诉Vue&#xff0c;某个属性的值已经发生了变化&#xff0c;从而触发视图的更新 le…

小程序中使用echarts地图

一、下载并安装echarts 1、下载echarts-for-weixin组件 echarts-for-weixin项目提供了一个小程序组件&#xff0c;用这种方式可以在小程序中方便地使用 ECharts。 下载ec-canvas项目&#xff08;下载地址&#xff09; ​​ 注意&#xff1a;下载的 ec-canvas 中的echarts的版本…

sql中COALESCE函数详解

在SQL中&#xff0c;COALESCE函数是一个非常有用的函数&#xff0c;用于从其参数列表中返回第一个非NULL值。如果所有给定的参数都是NULL&#xff0c;那么COALESCE函数将返回NULL。这个函数可以接受多个参数&#xff0c;使其在处理可能出现的NULL值时非常灵活和强大。 语法 C…

【Linux】协程简介

【Linux】协程简介 一、什么是协程&#xff1f;简介优点 二、为什么使用协程&#xff1f;三、协程的种类1、对称协程2、非对称协程 四、协程栈1、静态栈2、分段栈3、共享栈4、虚拟内存栈 五、协程调度1、栈式调度2、星切调度3、环切调度 六、常见协程库参考文献 一、什么是协程…

word embedding

介绍&#xff1a; ASCII可以编码为计算机可以识别的数据&#xff0c;为什么还需要embedding? 计算机只是对“字母”进行ASCII编码&#xff0c;并没有对词汇的“Word”编码。词汇应该是咱们处理自然语言的最基本的元素&#xff0c;而不是字母。那么世界上有千千万万的Word&am…

力扣381. O(1) 时间插入、删除和获取随机元素 - 允许重复

RandomizedCollection 是一种包含数字集合(可能是重复的)的数据结构。它应该支持插入和删除特定元素&#xff0c;以及删除随机元素。 实现 RandomizedCollection 类: RandomizedCollection()初始化空的 RandomizedCollection 对象。 bool insert(int val) 将一个 val 项插入到…

机器学习 | 模型评估和选择 各种评估指标总结——错误率精度-查准率查全率-真正例率假正例率 PR曲线ROC曲线

文章目录 1. 如何产生训练集和测试集呢&#xff1f;1.1 留出法1.2 K折交叉验证法1.3 自助法 2. 模型评估指标2.1 错误率和精度2.2 查准率和查全率与F12.2.1 PR曲线及其绘制 2.3 正例率和假例率2.3.1 ROC曲线图绘制及AUC 3 假设检验 1. 如何产生训练集和测试集呢&#xff1f; 1…

mac配置环境变量总结

1、启动终端Terminal 2、进入当前用户的home目录 输入 cd &#xff5e; (注意中间的空格) 3、创建 .bash_profile 文件 输入 touch .bash_profile 4、编辑 .bash_profile文件 输入 open -e .bash_profile .bash_profile文件内容 5、更新配置 source ~/.bash_profile…

Java的泛型特性和PECS特性

Java的泛型特性是Java SE 5引入的&#xff0c;它提供了编译时类型安全检测机制&#xff0c;这意味着程序可以在编译期间检测到类型错误&#xff0c;而不是在运行时。泛型的引入极大地增强了程序的类型安全性&#xff0c;减少了强制类型转换的需要。以下是Java泛型特性的详细解释…

【ACW 服务端】k8s部署

k8s部署 --- apiVersion: apps/v1 kind: Deployment metadata:annotations:k8s.kuboard.cn/displayName: 【wu-smart-acw-server】后台服务端labels:k8s.kuboard.cn/layer: svck8s.kuboard.cn/name: wu-smart-acw-servername: wu-smart-acw-servernamespace: defaultresourceV…

python 处理B站视频数据,数据存本地

python 处理B站视频数据&#xff0c;数据存本地 绪论实现1 导入头文件2. 获得数据的函数3 获取dvid4 获取数据&#xff0c;保存 后续 绪论 上一个已经通过B站的API&#xff0c;来实现了对数据的读取&#xff0c;这篇文章就是&#xff0c;将数据存储在本地的TXT文件中 上一篇文…

记autodl跑模型GPU CPU利用率骤变为0问题

目录 问题 解决 问题 实验室服务器资源紧张&#xff0c;博主就自己在autodl上租卡跑了&#xff0c;autodl有一个网络共享存储&#xff0c;可挂载至同一地区的不同实例中&#xff0c;当我们在该地区创建实例开机后&#xff0c;将会挂载文件存储至实例的/root/autodl-fs目录…

Grafana 安装指南

目录 介绍 安装 卸载 Grafana 汉化 介绍 Grafana是一款开源数据可视化平台&#xff0c;支持连接多种数据源&#xff0c;创建定制化仪表盘&#xff0c;通过直观的查询编辑器分析数据&#xff0c;设置灵活的警报规则并接收通知&#xff0c;具备丰富的插件生态系统&#xff0c…

韩国量子之梦:将量子计算纳入新增长 4.0战略

内容来源&#xff1a;量子前哨&#xff08;ID&#xff1a;Qforepost&#xff09; 编辑丨王珩 编译/排版丨沛贤 深度好文&#xff1a;1500字丨9分钟阅读 据《朝鲜邮报》报道&#xff0c;韩国将推出由量子计算加速的云服务&#xff0c;并在首尔地区启动城市空中交通的试飞&…

微信小程序订阅消息前后端示例

微信小程序的订阅消息&#xff0c; 必须是由弹框&#xff0c;弹框&#xff0c;弹框来调起了&#xff0c;单纯的在页面上调用 wx.requestSubscribeMessage是没有效果的 小程序端的代码 <view class"sub" bindtap"dinyuxiaoxi">订阅消息</view>…

Leetcoder Day27| 贪心算法part01

语言&#xff1a;Java/Go 理论 贪心的本质是选择每一阶段的局部最优&#xff0c;从而达到全局最优。 什么时候用贪心&#xff1f;可以用局部最优退出全局最优&#xff0c;并且想不到反例到情况 贪心的一般解题步骤 将问题分解为若干个子问题找出适合的贪心策略求解每一个子…