news 2026/4/23 12:49:12

有效的完全平方数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
有效的完全平方数

文章目录

  • 一、读题
  • 二、算法思路
  • 三、代码实现:

一、读题

题目来源:https://leetcode.cn/problems/valid-perfect-square/


题目很简单,就是判断一个数是不是完全平方数,是就返回true,不是就返回false,主包就喜欢这种第一眼就可以理解的题目哈哈哈

二、算法思路

方法一:这个题目本质也还是暴力题,判断一个数是不是完全平方数,那很简单啊,遍历嘛,从1开始遍历,直到等于num,如果找不到就说明没有,如果找到中途就直接返回结果。时间复杂度是O(n)的。

方法二:其实是方法一的优化版,我们使用二分查找可以对这个遍历的过程进行优化,每一次的二分查找结果都和num进行比较,当然了二分查找相信各位佬都是手拿把掐的,主包就不献丑了哈,可以直接看代码。时间复杂度可以优化为O(logn)的。

方法三:这个方法是一个数学方法,我们使用奇数从1开始相加,如果最终相加能够得到num,那么说明num就是完全平方数。例:4 = 1 + 3 ,9 = 1 + 3 + 5,16 = 1 + 3 + 5 + 7;时间复杂度是O(n)

原理是什么呢?不知道大家还记不记得高中学的等差数列求和,这个原理 就是根据等差数列得到的,大家可以不必要知道原理是什么,会算就可以了,有兴趣的可以继续看主包讲解,没有兴趣的可以直接看代码

16 = 1 + 3 + 5 + 7 推导得出 :S=1+3+5+7 … +(2n - 3) +(2n-1)

这个是奇数相加,我们可以直观的看出来两数之间的差是2,那说明这是一个公差为2的等差数列

等差数列求和的公式是:(首项+末项)*项数 /2

首项:1

末项 :(2n-1)

项数:n
(假设当前我的最后一项是15,那么对应就是1,3,5,7,9,11,13,15,15=(2n-1)那么n就等于8,所以项数就是8)

代入公式就得:(1 + 2n - 1) * n / 2 = n^2
说明奇数相加的结果一定是偶数,并且是一个完全平方数

验算:当n=8的时候,平方数是64,1+3+5+7 +9 +11 +13 + 15=64,

三、代码实现:

public boolean isPerfectSquare(int num) { //方法二:遍历,二分优化 ,方法一就不写了,相信大家都会 if (num == 0 || num == 1) return true; int left = 0; int right = num / 2; while (left <= right) { int mid = (right - left) / 2 + left; long ans = (long) mid * mid; if (num == ans) { return true; } else if (num > ans) { left = mid + 1; } else { right = mid - 1; } } return false; } }
class Solution { public boolean isPerfectSquare1(int num) { //方法三:数学思路,完全平方数一定是可以由不同的奇数组合而成(从1开始逐渐增大的奇数) int ans = 1; while (num > 0) { num -= ans; ans += 2; } // System.out.println(num); return num == 0; }

各位佬,如果有什么更加高效的算法欢迎评论区讨论,指导一下主包进步,原诸君共勉

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 11:27:39

YOLOv8训练日志解读:如何监控学习过程?

YOLOv8训练日志解读&#xff1a;如何监控学习过程&#xff1f; 在目标检测的实际项目中&#xff0c;模型跑完训练只是第一步。真正决定成败的&#xff0c;是能否读懂它“学得怎么样”——损失是不是在稳步下降&#xff1f;mAP有没有饱和迹象&#xff1f;学习率调度是否按预期执…

作者头像 李华
网站建设 2026/4/18 10:56:04

array 这个是服务器的什么信息

hardware.array 通常指代服务器硬件阵列信息&#xff0c;核心是 RAID 阵列&#xff08;独立磁盘冗余阵列&#xff09;的相关配置与状态数据&#xff0c;属于服务器硬件监控的核心指标之一。 一、 具体包含的信息 在服务器监控场景&#xff08;如 SNMP、IPMI、或硬件管理工具&am…

作者头像 李华
网站建设 2026/4/23 11:28:04

GitHub热门项目YOLOv8部署指南:Docker Run快速上手

GitHub热门项目YOLOv8部署指南&#xff1a;Docker Run快速上手 在智能视觉应用日益普及的今天&#xff0c;开发者面临的最大挑战之一不再是“模型能不能跑”&#xff0c;而是“环境配不配得通”。尤其是在目标检测这类依赖复杂深度学习框架的场景中&#xff0c;CUDA、PyTorch、…

作者头像 李华
网站建设 2026/4/20 3:17:48

QListView支持拖拽排序功能的从零实现

如何让 QListView 支持拖拽排序&#xff1f;一篇讲透 Qt 模型视图的实战技巧你有没有遇到过这样的需求&#xff1a;用户想调整播放列表顺序、重新排列任务项&#xff0c;或者自定义菜单栏布局&#xff1f;这时候&#xff0c;“点按钮上下移动”显然太原始了。真正现代的交互方式…

作者头像 李华
网站建设 2026/4/23 11:34:26

YOLOv8与HuggingFace集成可能性探讨

YOLOv8与HuggingFace集成可能性探讨 在智能安防、自动驾驶和工业质检等现实场景中&#xff0c;开发者常常面临一个尴尬的困境&#xff1a;手握性能强劲的目标检测模型&#xff0c;却因部署门槛高、共享流程繁琐而难以快速验证其价值。YOLOv8正是这样一位“能打但难推”的选手—…

作者头像 李华
网站建设 2026/4/18 14:29:37

YOLOv8能否用于珊瑚礁恢复监测?种植成效评估

YOLOv8能否用于珊瑚礁恢复监测&#xff1f;种植成效评估 在海洋生态日益脆弱的今天&#xff0c;珊瑚礁——这片被誉为“海底热带雨林”的生态系统&#xff0c;正面临前所未有的生存威胁。海水升温、酸化、过度捕捞和人类活动干扰&#xff0c;使得全球范围内的珊瑚白化事件频发。…

作者头像 李华