动态规划问题<递归问题>1
时间:2020-03-24
本文章向大家介绍动态规划问题<递归问题>1,主要包括动态规划问题<递归问题>1使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
leetcode 每日一题日常打卡 面试题 17.16 按摩师问题 首先是问题描述: 一个有名的按摩师会收到源源不断的预约请求,每个预约都可以选择接或不接。在每次预约服务之间要有休息时间,因此她不能接受相邻的预约。给定一个预约请求序列,替按摩师找到最优的预约集合(总预约时间最长),返回总的分钟数。 思考:由于是个新手,刚接触这道题想了十几分钟完全没有任何思路,通过查资料得知这种求最优解的问题一般都是通过动态规划求解。 但是我突然想到应该也可以用递归求解!通过创建一个循环,从数组第0个元素开始遍历,因为这个问题是不能取临近的值,因此,下面通过手写讲诉:
class Solution { public: int massage(vector<int>& nums) { vector<int> a; //创建一个存放每次遍历出结果的数组 int i = 0; vector<int >::iterator it = nums.begin(); if(1 == nums.size()) //如果该数组只有一个元素,那么直接返回它就行 { return nums.front(); } if(2 == nums.size()) //如果有两个元素,那么直接比较大小,返回大的即可,这也是递归的结束条件 { return nums.front()>nums.back()?nums.front():nums.back(); } if(nums.size()>2) { while(i<nums.size()) { vector<int > c = nums; if(i+2>nums.size()) { break; } //ans[i] = nums[i]+massage((nums+i+2),numsSize-i-2); c.erase(c.begin(),c.begin()+i+2); int val = nums.at(i)+massage(c); //通过递归方式得出每一次的值 a.push_back(val); i++; } sort(a.begin(),a.end()); //排序从小到大 return a.back(); } return 0; } };
原文地址:https://www.cnblogs.com/-mySmellerArea/p/12559092.html
- 论golang是世界上最好的语言
- 用shape画内圆外方,形成一个圆形头像
- 在Go中对gRPC+ProtoBuf与Http+Json进行基准测试
- Achartengine.jar绘制动态图形一 --饼图
- 工具| 关于Python线程和队列使用的小思考
- Java中list<Object[]>、list<Student>、list<Map<String,String>>排序
- Java-单例模式详解(图文并茂,简单易懂)
- Fragment生命周期及实现点击导航图片切换fragment,Demo
- 《GO IN ACTION》读后记录:GO的并发与并行
- SharedPreferences 存List集合,模拟数据库,随时存取
- Servlet与Jsp的结合使用实现信息管理系统一
- Mac下nvm管理node.js版本问题
- 自定义tab吸顶效果一(原理)
- OpenGL ES学习001---绘制三角形
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法