LeetCode(977):有序数组的平方

有序数组的平方

题目链接

题目:给你一个按非递减顺序排序的整数数组 nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。

cpp 复制代码
//暴力 
#include<stdio.h>
void sort(int *nums,int n){
	for(int i=0;i<n;i++)
		for(int j=i+1;j<n;j++){
			if(nums[i]>nums[j]){
				int temp=nums[i];
				nums[i]=nums[j];
				nums[j]=temp;
			}
		}
}

int main(){
	int nums[]={-4,-1,0,3,10};
	int n=sizeof(nums)/sizeof(nums[0]);
	for(int i=0;i<n;i++)
		nums[i]=nums[i]*nums[i];
	sort(nums,n);
	for(int i=0;i<n;i++)
		printf("%d ",nums[i]);
} 

聪明方法:双指针

数组其实是有序的,只不过负数平方之后可能成为最大数了。那么数组平方的最大值就在数组的两端,不可能是中间。此时可以考虑双指针,分别指向头和尾。

并且此题没规定空间复杂度,故可以新建一个数组。

cpp 复制代码
//双指针
//学会这个思想的变化
#include<stdio.h>
int main(){
	int nums[]={-11,-2,3,4,5,6,7};
	int n=sizeof(nums)/sizeof(nums[0]);
	int result[n];//构建一个新数组
	int k=n-1;//作为新数组的索引
	//***由于原数组两边的平方比中间大,并且大的要在新数组后面,故初始值为n-1 
	for(int i=0,j=n-1;i<=j;){ //定义两个指向头和尾的索引;注意:i<=j,因为最后还有一个元素要加进去 
		if(nums[i]*nums[i]<nums[j]*nums[j]){
			result[k--]=nums[j]*nums[j];
			j--;
		} 
		else{
			result[k--]=nums[i]*nums[i];
			i++;
		}
	}
	for(int i=0;i<n;i++)
		printf("%d ",result[i]);
} 
相关推荐
情缘晓梦.5 小时前
C语言数据存储
c语言·开发语言
im_AMBER5 小时前
Leetcode 99 删除排序链表中的重复元素 | 合并两个链表
数据结构·笔记·学习·算法·leetcode·链表
SmartRadio6 小时前
MK8000(UWB射频芯片)与DW1000的协议适配
c语言·开发语言·stm32·单片机·嵌入式硬件·物联网·dw1000
源代码•宸6 小时前
Leetcode—1123. 最深叶节点的最近公共祖先【中等】
经验分享·算法·leetcode·职场和发展·golang·dfs
alphaTao6 小时前
LeetCode 每日一题 2026/1/5-2026/1/11
算法·leetcode
山上三树6 小时前
详细介绍 C 语言中的 #define 宏定义
c语言·开发语言·算法
麻雀1237 小时前
win7中编译qemu-system-arm,仿真arm设备
c语言·eclipse
黎雁·泠崖7 小时前
二叉树知识体系全梳理:从基础到进阶一站式通关
c语言·数据结构·leetcode
山上三树7 小时前
详细介绍 C/C++ 中的内存泄漏
c语言·c++
Legendary_0087 小时前
LDR6020:单C口可充可放电PD协议芯片,开启USB2.0数据传输新体验
c语言·开发语言