[leetCode]977. 有序数组的平方
解法 双指针
定义两个指针指向数组前后,比较指向元素的平方大小,从答案数组之后向前填充
class Solution {
public int[] sortedSquares(int[] A) {
if (A == null) return null;
int n = A.length;
int[] ans = new int[n];
int i = 0, j = n - 1, p = n-1;
while (i <= j ) {
if (A[i]*A[i] > A[j]*A[j]) {
ans[p] = A[i] * A[i];
i++;
} else {
ans[p] = A[j] * A[j];
j--;
}
p--;
}
return ans;
}
}
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】Flutter适配HarmonyOS 5知识地图,实战解析+高频避坑指南
【推荐】凌霞软件回馈社区,携手博客园推出1Panel与Halo联合终身会员
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· tomcat为什么假死了
· 聊一聊 Linux 上对函数进行 hook 的两种方式
· C# 锁机制全景与高效实践:从 Monitor 到 .NET 9 全新 Lock
· 一则复杂 SQL 改写后有感
· golang中写个字符串遍历谁不会?且看我如何提升 50 倍
· 完成微博外链备案,微博中直接可以打开园子的链接
· 推荐 3 种 .NET Windows 桌面应用程序自动更新解决方案
· 一个基于 .NET 开源、模块化 AI 图像生成 Web 用户界面
· .NET 10 支持Linux/Unix 的Shebang(Hashbang)
· C#实现欧姆龙 HostLink 通讯协议库