PHP如何实现有序数组平方排序的算法?
- 内容介绍
- 文章标签
- 相关推荐
本文共计657个文字,预计阅读时间需要3分钟。
给定一个非递减顺序排列的整数数组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
内置函数求解
代码
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分钟。
给定一个非递减顺序排列的整数数组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
内置函数求解
代码
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如何实现有序数组的平方的详细内容,更多请关注自由互联其它相关文章!

