当前位置: 首页 > news >正文

力扣279. 完全平方数

动态规划

  • 思路:
    • 假设 dp[i] 为最少组成数 i 的平方数个数;
    • 则其上一个状态为 dp[i - j^2] + 1,1 为 j^2:
      • 即 i 的最少完全平方数 = i - j^2 的最少完全平方数 + 1,其中 j^2  <= i 为最接近 i 的平方数;
    • 初始值:dp[0] = 0
    • 所以,可以通过动态规划算出每一个 dp[i]
class Solution {
public:int numSquares(int n) {std::vector<int> dp(n + 1);dp[0] = 0;for (int i = 1; i <= n; ++i) {int minn = INT_MAX;for (int j = 1; j * j <= i; ++j) {minn = std::min(minn, dp[i - j * j]);}dp[i] = minn + 1;}return dp[n];}
};

——————————————————————————————

http://www.lryc.cn/news/286498.html

相关文章:

  • 【C++】list容器功能模拟实现
  • linux 安装ffmpeg
  • 激光雷达行业梳理2-产业链、公司、未来展望
  • Java 设计者模式以及与Spring关系(四) 代理模式
  • PHP编程实践:实际商品价格数据采集
  • 有效防范网络风险的关键措施
  • Spring Boot整合webservice
  • Qt拖拽事件简单实现
  • 上门回收小程序,打造回收新模式
  • unity项目《样板间展示》开发:火焰和UI设计
  • 即插即用篇 | UniRepLKNet:用于音频、视频、点云、时间序列和图像识别的通用感知大卷积神经网络 | DRepConv
  • MPU6050传感器—姿态检测
  • PaddleOCR封装,在线服务化部署实战(python部署,超新手教程)
  • 采集B站up主视频信息
  • Laykefu客服系统 任意文件上传漏洞复现
  • 《幻兽帕鲁》服务器该如何选购
  • 比较有创意的网站
  • alfred自定义谷歌翻译workflow
  • 【网络安全 -> 防御与保护】专栏文章索引
  • 用户资源(菜单)控制学习使用
  • 邦芒支招:十大秘诀助你轻松进名企
  • 5G_射频测试_参考规范(一)
  • 幻读是什么,用什么隔离级别可以防止幻读?
  • UE5 C++学习笔记 FString FName FText相互转换
  • 【ASOC全解析(三)】machine原理和实战
  • matlab appdesigner系列-常用15-滑块、微调器
  • google翻译相机报错 请安装最新的Google应用,以便使用相机翻译功能
  • openssl3.2/test/certs - 015 - Primary intermediate ca: ca-cert
  • linux中用户及用户组信息
  • 用Go plan9汇编实现斐波那契数列计算