977. 有序数组的平方
给你一个按非递减顺序排序的整数数组 nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。
示例 1:
输入:nums = [-4,-1,0,3,10]
输出:[0,1,9,16,100]
解释:平方后,数组变为 [16,1,0,9,100]
排序后,数组变为 [0,1,9,16,100]
示例 2:
输入:nums = [-7,-3,2,3,11]
输出:[4,9,9,49,121]
class Solution {
public :
vector<int > sortedSquares (vector<int >& nums) {
for (int i = 0 ; i < nums.size (); i++)
{
nums[i] = nums[i] * nums[i];
}
sort (nums.begin (), nums.end ());
return nums;
}
};
209. 长度最小的子数组
给定一个含有 n 个正整数的数组和一个正整数 target。
找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl+1, ..., numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0。
示例 1:
输入:target = 7 , nums = [2 ,3 ,1 ,2 ,4 ,3 ]
输出:2
解释:子数组 [4 ,3 ] 是该条件下的长度最小的子数组。
示例 2:
输入:target = 4 , nums = [1 ,4 ,4 ]
输出:1
示例 3:
输入:target = 11 , nums = [1 ,1 ,1 ,1 ,1 ,1 ,1 ,1 ]
输出:0
class Solution {
public :
int minSubArrayLen (int target, vector<int >& nums) {
int result = INT32_MAX;
int subLength = 0 ;
int sum = 0 ;
int i = 0 ;
for (int j = 0 ; j < nums.size (); j++)
{
sum += nums[j];
while (sum >= target)
{
subLength = j - i + 1 ;
result = result < subLength ? result : subLength;
sum -= nums[i];
i++;
}
}
return result == INT32_MAX ? 0 : result;
}
};
59. 螺旋矩阵 II
给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。
示例 1:
输入:n = 3
输出:[[1,2,3],[8,9,4],[7,6,5]]
示例 2:
输入:n = 1
输出:[[1]]
class Solution {
public :
vector<vector<int >> generateMatrix (int n) {
vector<vector<int >> nums (n, vector <int >(n, 0 ));
int i, j;
int count = 1 ;
int startx = 0 ;
int starty = 0 ;
int middle = n / 2 ;
int loop = n / 2 ;
int offset = 1 ;
while (loop--)
{
for (j = startx; j < n - offset; j++)
{
nums[startx][j] = count++;
}
for (i = starty; i < n - offset; i++)
{
nums[i][n - offset] = count++;
}
for (; j > startx; j--)
{
nums[n - offset][j] = count++;
}
for (; i > startx; i--)
{
nums[i][j] = count++;
}
startx++;
starty++;
offset++;
}
if (n % 2 == 1 )
{
nums[middle][middle] = count;
}
return nums;
}
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程