显然,两个思路动态规划
class Solution {
public:
int getMaxLen(vector<int>& nums) {
int n = nums.size();
int res;
vector<int> f(n), g(n);
if (nums[0] > 0) {
f[0] = 1;
}
if (nums[0] < 0) {
g[0] = 1;
}
res = f[0];
for (int i = 1; i < n; i++) {
if (nums[i] > 0) {
f[i] = f[i - 1] + 1;
if (g[i - 1] == 0) {
g[i] = 0;
} else if (g[i - 1] > 0) {
g[i] = g[i - 1] + 1;
}
} else if (nums[i] < 0) {
g[i] = f[i - 1] + 1;
if (g[i - 1] > 0) {
f[i] = g[i - 1] + 1;
} else if (g[i - 1] == 0) {
f[i] = 0;
}
}
res = max(res, f[i]);
}
return res;
}
};