PHP如何实现有序数组平方排序的算法?

2026-04-06 17:081阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计657个文字,预计阅读时间需要3分钟。

PHP如何实现有序数组平方排序的算法?

给定一个非递减顺序排列的整数数组A,返回每个数字的平方组成的新的数组,且新数组也需保持非递减顺序。

以下是一个PHP实现的示例:

phpfunction sortedSquares($A) { $n=count($A); $squares=array_fill(0, $n, 0); $left=0; $right=$n - 1; $index=$n - 1;

while ($left $A[$right] * $A[$right]) { $squares[$index]=$A[$left] * $A[$left]; $left++; } else { $squares[$index]=$A[$right] * $A[$right]; $right--; } $index--; }

return $squares;}

// 示例$A=[-4, -1, 0, 3, 10];$result=sortedSquares($A);print_r($result); // 输出: Array ( [0]=> 0 [1]=> 1 [2]=> 9 [3]=> 16 [4]=> 100 )

这段代码首先创建了一个与原数组长度相同的新数组`squares`,用于存储平方后的结果。然后使用双指针技术,一个从数组的左侧开始,另一个从右侧开始,比较两个指针指向的元素的平方,将较大的平方值放入`squares`数组的末尾,并移动相应的指针。这样,新数组`squares`在填充过程中始终保持非递减顺序。

给定一个按非递减顺序排序的整数数组A,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。今天小编就来介绍一下PHP实现有序数组平方的方法,有需要的可以参考一下。

给定一个按非递减顺序排序的整数数组 A,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。

示例 1:

输入:[-4,-1,0,3,10] 输出:[0,1,9,16,100]

示例 2:

输入:[-7,-3,2,3,11] 输出:[4,9,9,49,121]

解题思路 1

内置函数求解

PHP如何实现有序数组平方排序的算法?

代码

class Solution { /** * @param Integer[] $A * @return Integer[] */ function sortedSquares($A) { foreach ($A as &$item) { $item = $item * $item; } sort($A); return $A; }}

解题思路 2

双指针遍历,同时借助新数组,将计算平方之后的结果从大到小放到新数组。

class Solution { /** * * * 2 为自乘 2 次,也是平方 * @param Integer[] $A * @return Integer[] */ function sortedSquares($A) { $ans = []; $i = 0; $j = count($A) - 1; $k = count($A) - 1; while ($i <= $j) { // 原数组是有序的,所以 -$A[$i] > $A[$j] 即为 $A[$i] 的绝对值平方后更大 if (-$A[$i] > $A[$j]) { $ans[$k--] = $A[$i] ** 2; // 左指针向右移动 $i++; } else { $ans[$k--] = $A[$j] ** 2; $j--; } } return $ans; }}

推荐学习:php视频教程

以上就是PHP如何实现有序数组的平方的详细内容,更多请关注自由互联其它相关文章!

标签:平方给定

本文共计657个文字,预计阅读时间需要3分钟。

PHP如何实现有序数组平方排序的算法?

给定一个非递减顺序排列的整数数组A,返回每个数字的平方组成的新的数组,且新数组也需保持非递减顺序。

以下是一个PHP实现的示例:

phpfunction sortedSquares($A) { $n=count($A); $squares=array_fill(0, $n, 0); $left=0; $right=$n - 1; $index=$n - 1;

while ($left $A[$right] * $A[$right]) { $squares[$index]=$A[$left] * $A[$left]; $left++; } else { $squares[$index]=$A[$right] * $A[$right]; $right--; } $index--; }

return $squares;}

// 示例$A=[-4, -1, 0, 3, 10];$result=sortedSquares($A);print_r($result); // 输出: Array ( [0]=> 0 [1]=> 1 [2]=> 9 [3]=> 16 [4]=> 100 )

这段代码首先创建了一个与原数组长度相同的新数组`squares`,用于存储平方后的结果。然后使用双指针技术,一个从数组的左侧开始,另一个从右侧开始,比较两个指针指向的元素的平方,将较大的平方值放入`squares`数组的末尾,并移动相应的指针。这样,新数组`squares`在填充过程中始终保持非递减顺序。

给定一个按非递减顺序排序的整数数组A,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。今天小编就来介绍一下PHP实现有序数组平方的方法,有需要的可以参考一下。

给定一个按非递减顺序排序的整数数组 A,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。

示例 1:

输入:[-4,-1,0,3,10] 输出:[0,1,9,16,100]

示例 2:

输入:[-7,-3,2,3,11] 输出:[4,9,9,49,121]

解题思路 1

内置函数求解

PHP如何实现有序数组平方排序的算法?

代码

class Solution { /** * @param Integer[] $A * @return Integer[] */ function sortedSquares($A) { foreach ($A as &$item) { $item = $item * $item; } sort($A); return $A; }}

解题思路 2

双指针遍历,同时借助新数组,将计算平方之后的结果从大到小放到新数组。

class Solution { /** * * * 2 为自乘 2 次,也是平方 * @param Integer[] $A * @return Integer[] */ function sortedSquares($A) { $ans = []; $i = 0; $j = count($A) - 1; $k = count($A) - 1; while ($i <= $j) { // 原数组是有序的,所以 -$A[$i] > $A[$j] 即为 $A[$i] 的绝对值平方后更大 if (-$A[$i] > $A[$j]) { $ans[$k--] = $A[$i] ** 2; // 左指针向右移动 $i++; } else { $ans[$k--] = $A[$j] ** 2; $j--; } } return $ans; }}

推荐学习:php视频教程

以上就是PHP如何实现有序数组的平方的详细内容,更多请关注自由互联其它相关文章!

标签:平方给定