力扣-279.完全平方數

題目描述

給你一個整數 n ,返回 和為 n 的完全平方數的最少數量 。

完全平方數 是一個整數,其值等于另一個整數的平方;換句話說,其值等于一個整數自乘的積。例如,1、4、9 和 16 都是完全平方數,而 3 和 11 不是。

class Solution {public int numSquares(int n) {int[] nums = new int[102];for(int i = 1; i <= 101; i++){nums[i] = i*i;}int[] dp = new int[n+1];    //dp數組是最后答案,和為n最少個數for(int i = 1; i <= n; i++){dp[i] = i;  //最差的可能是全1for(int j = 1;i-nums[j]>=0;j++){dp[i] = Math.min(dp[i],dp[i-nums[j]]+1);    //輪流用不超過n的完全平方數做替換}}return dp[n];}
}

小結:還是一維的dp,要考慮每個數用完全平方數與不用完全平方數之間哪個最優,且不大于該數的完全平方數都要試一遍。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/84720.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/84720.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/84720.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

前端構建工具Webapck、Vite——>前沿字節開源Rspack詳解——2023D2大會

Rspack 以下是針對主流構建工具&#xff08;Webpack、Vite、Rollup、esbuild&#xff09;的核心不足分析&#xff0c;以及 Rspack 如何基于這些痛點進行針對性改進 的深度解析&#xff1a; 一、主流構建工具的不足 1. Webpack&#xff1a;性能與生態的失衡 核心問題 冷啟動慢…

輸入法,開頭輸入這U I V 三個字母會不顯示 任何中文

1. 漢語拼音規則的限制 漢語拼音中不存在以“V”“U”“I”為聲母的情況&#xff1a; 漢語拼音的聲母是輔音&#xff0c;而“V”“U”“I”在漢語拼音中都是元音&#xff08;或韻母的一部分&#xff09;。漢語拼音的聲母系統中沒有“V”“U”“I”作為聲母的音節。例如&#xf…

Linux文件權限詳解:從入門到精通

前言 權限是什么&#xff1f; 本質&#xff1a;無非就是能做和不能做什么。 為什么要有權限呢&#xff1f; 目的&#xff1a;為了控制用戶行為&#xff0c;防止發生錯誤。 1.權限的理解 在學習下面知識之前要先知道的一點是&#xff1a;linux下一切皆文件&#xff0c;對li…

在多云環境透析連接ngx_stream_proxy_protocol_vendor_module

1、模塊定位與價值 多云接入&#xff1a;在同一 Nginx 實例前端接入來自多云平臺的私有鏈路時&#xff0c;能區分 AWS、GCP、Azure 特有的連接 ID。安全審計&#xff1a;自動記錄云平臺側的 Endpoint/VPC ID&#xff0c;有助于聯調和安全事件追蹤。路由分流&#xff1a;基于不…

力扣:基本計算器

基本計算器: 224. 基本計算器 - 力扣&#xff08;LeetCode&#xff09; 本體思路為&#xff0c;將中綴表達式轉為后綴表達式&#xff0c;通過后綴表達式進行運算。 中綴表達式: 我們日常生活中熟知的表達式如12-30 就是一個中綴表達式。 后綴表達式: 150. 逆波蘭表達式求值 - …

《AI日報 · 0613|ChatGPT支持導出、Manus免費開放、GCP全球宕機》

AI 資訊 1?? OpenAI ChatGPT Canvas新增多格式導出功能 OpenAI終于為ChatGPT Canvas推出了用戶期待已久的導出功能。現在,用戶可以將創作內容導出為多種格式:文檔類支持PDF、docx和markdown格式,代碼文件則可直接保存為對應擴展名的源文件(如.py、.js、.sql等)。這一功…

C++中的零拷貝技術

一、C中零拷貝技術的核心概念 零拷貝&#xff08;Zero-copy&#xff09;是一種重要的優化技術&#xff0c;旨在減少數據在內存中的不必要復制&#xff0c;從而提高程序性能、降低內存使用并減少CPU消耗。在C中&#xff0c;零拷貝技術通過多種方式實現&#xff0c;包括引用語義…

RT_Thread內核源碼分析(五)——內存管理@小堆內存管理算法

目錄 1、內存堆控制 1.1 內存堆控制器 1.2 內存塊節點 1.3 內存堆管理 2、內存堆初始化 2.1 初始化接口 2.2 初始化示例 2.3 源碼分析 3、內存堆操作 3.1 內存塊申請 3.1.1 相關接口 3.1.2 原理分析 3.1.3 示例分析 3.1.4 代碼分析 3.2 內存塊伸縮 3.2.1 相關…

MyBatis-Plus 混合使用 XML 和注解

mybatisplus代碼生成器&#xff1a; 版本匹配是個比較麻煩的問題&#xff0c;這是我的配置&#xff1a; <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.2</version>…

基于ssm的教學質量評估系統

博主介紹&#xff1a;java高級開發&#xff0c;從事互聯網行業六年&#xff0c;熟悉各種主流語言&#xff0c;精通java、python、php、爬蟲、web開發&#xff0c;已經做了六年的畢業設計程序開發&#xff0c;開發過上千套畢業設計程序&#xff0c;沒有什么華麗的語言&#xff0…

【STM32】G030單片機開啟超過8個ADC通道的方法

如圖所示通道數量已經超過8個&#xff0c;按照之前博客的辦法已經行不通了 CubeMX配置STM32F103C8T6多路ADC配合DMA采集_stm32f103c8t6的adc采樣率-CSDN博客 這里筆者開了10個channel&#xff0c;注意切換為不完全配置&#xff0c;否則的話最多只有8個rank 開DMA&#xff0c;…

不同網絡I/O模型的原理

目錄 1、I/O的介紹 1.1、I/O 操作分類 1.2、I/O操作流程階段 1.3、I/O分類 2、同步I/O 2.1、阻塞I/O 2.2、非阻塞I/O 2.3、I/O復用 2.4、信號驅動式I/O 3、異步I/O 前言 在網絡I/O之中&#xff0c;I/O操作往往會涉及到兩個系統對象&#xff0c;一個是用戶空間調用I/O…

在正則表達式中語法 (?P<名字>內容)

&#x1f3af; 重點解釋&#xff1a;?P<xxx> 是什么語法&#xff1f; 這一整段&#xff1a; (?P<xxx>...)是 Python 正則表達式中 “命名捕獲組” 的語法。 咱們現在一個字一個字來解釋&#xff1a; ? (?...) 是干啥的&#xff1f; 這是一個捕獲組&#xff…

中興B860AV1.1_MSO9280_降級后開ADB-免刷機破解教程(非刷機)

中興B860AV1.1江蘇移動-自動降級包 關于中興b860av1.1頑固盒子降級教程終極版 將附件解壓好以后&#xff0c;準備一個8G以下的U盤重新格式化為FAT32格式后&#xff0c;并插入電腦 將以下文件及文件夾一同復制到優盤主目錄下&#xff08;見下圖&#xff09; 全選并復制到U盤主目…

2025-06-13【視頻處理】基于視頻內容轉場進行分割

問題&#xff1a;從網上下載的視頻文件&#xff0c;是由很多個各種不同的場景視頻片段合并而成。現在要求精確的把各個視頻片段從大視頻里分割出來。 效果如圖&#xff1a;已分割出來的小片段 思考過程 難點在于檢測場景變化。為什么呢&#xff1f;因為不同的視頻情況各異&am…

ReentrantLock和RLock

文章目錄 前言一、 ReentrantLock&#xff08;單機鎖&#xff0c;Java 內置&#xff09;示例&#xff1a;方法詳解 二、RLock&#xff08;分布式鎖&#xff0c;Redisson 提供&#xff09;示例:方法詳解 三、 對比總結:四、 如何選擇&#xff1f; 前言 ReentrantLock 和 RLock 都…

thinkphp ThinkPHP3.2.3完全開發手冊

慣例配置 應用設定 APP_USE_NAMESPACE > true, // 應用類庫是否使用命名空間 3.2.1新增 APP_SUB_DOMAIN_DEPLOY > false, // 是否開啟子域名部署 APP_SUB_DOMAIN_RULES > array(), // 子域名部署規則 APP_DOMAIN_SUFFIX > , // 域名后綴 如果是…

Python Day50 學習(仍為日志Day19的內容復習)

補充&#xff1a;梳理超參數調整流程&#xff08;邏輯&#xff09; 超參數調節的流程邏輯可以總結為以下幾個步驟&#xff1a; 1. 明確目標 確定你要優化的模型和評估指標&#xff08;如準確率、F1值、AUC等&#xff09;。 2. 選擇要調節的超參數 列出模型中影響較大的超參數…

公司網絡變差的解決方法(固定IP地址沖突)

問題描述 最近公司網絡變差&#xff0c;不知道為什么。&#xff08;別的同事反饋的&#xff0c;本人沒有感覺變差&#xff0c;也是比較奇怪的現象&#xff09; 現象有視頻會議變卡等。 調查過程 1.領導給網絡公司打電話溝通&#xff0c;對面遠程看了下&#xff0c;不是設備問…

使用Prometheus+Grafana+Alertmanager+Webhook-dingtalk搭建監控平臺

一、監控平臺介紹 1.監控平臺簡述普羅米修斯四件套,分別為Prometheus、Grafana、Alertmanager、Webhook-DingTalk。Prometheus一套開源的監控&報警&時間序列數據庫的組合,由SoundCloud公司開發,廣泛用于云原生環境和容器化應用的監控和性能分析。其提供了通用的數據…