leetcode118杨辉三角
VS2022调试vector,我给res添加了监视器,三个断点期间,res的size一直都是0
vectorint>> generate(int numRows) {
//先初始化一个numRow行的二维数组,每一列初始化为1个0
vectorint>> res(numRows, vector<int>(1, 0));
//根据杨辉三角的特性重新初始化每一列
for (int i = 0; i < numRows; i++) {
res[i].resize(i + 1);
}
for (int i = 0; i < numRows; i++) {
for (int j = 0; j < res[i].size(); j++) {
if (j == 0 || j == i)
res[i][j] = 1;
else
res[i][j] = res[i - 1][j - 1] + res[i - 1][j];
}
}
return res;
}
参考ChatGPT的解释:
你的代码本身是没有问题的,而且你说调用函数后可以输出正确结果,说明函数本身也是正确的。因此,问题可能出在你的调试方法上。
首先,你在调试前应该先运行代码,确保你的代码可以正常编译并运行。然后,在你的代码中添加断点,以便在运行过程中暂停代码执行,以便检查变量的值。如果你在调试时添加了断点,但是发现变量值没有更新,那么这可能是因为你没有按照正确的顺序执行代码。例如,你在添加断点之前就结束了程序,或者你没有进入你的函数。你应该确保程序正常运行并进入你的函数,然后再添加断点,以便正确检查变量的值。
此外,你可以在函数内部使用cout语句输出变量的值,以便调试时可以更直观地了解变量的值。
最后,如果你使用的是VS Code,可以尝试在launch.json中添加"externalConsole": true来打开独立的命令行窗口,以便在控制台中查看程序输出。
综上所述,你的代码没有问题,但是可能需要改进你的调试方法以便更好地检查变量的值。
不知道你这个问题是否已经解决, 如果还没有解决的话:给定一个非负整数数组 A,返回一个数组,在该数组中, A 的所有偶数元素之后跟着所有奇数元素。
你可以返回满足此条件的任何数组作为答案。
示例:
输入:[3,1,2,4]
输出:[2,4,3,1]
输出 [4,2,3,1],[2,4,1,3] 和 [4,2,1,3] 也会被接受。
提示:
1 <= A.length <= 5000
0 <= A[i] <= 5000
思路:
1、通过遍历数组找到里面的偶数
2、设置i,j两个角标,i用来遍历数组,j = 0,用来做交换
3、只要将偶数换到前面就可以了,所以在遍历时发现偶数时就把这个偶数换到数组的第一位,第二位…最后返回数组的值就可以了
class Solution {
public int[] sortArrayByParity(int[] A) {
int n = A.length;
int j = 0;
for(int i = 0; i < n; i++){
int x = A[i];
if(x % 2 == 0){
int temp =A[j];
A[j] = A[i];
A[i] = temp;
j++;
}
}
return A;
}
}
—————————————————————————————