2708. 一个小组的最大实力值

2708. 一个小组的最大实力值


题目链接:2708. 一个小组的最大实力值

代码如下:

cpp 复制代码
class Solution
{
public:
	long long maxStrength(vector<int>& nums)
	{
		long long res = 1;
		int negativeCnt = 0, positiveCnt = 0, zeroCnt = 0;
		int maxNegative = INT_MIN;

		for (int i = 0; i < nums.size(); i++)
		{
			if (nums[i] < 0)
			{
				negativeCnt++;
				res *= nums[i];
				maxNegative = max(maxNegative, nums[i]);
			}
			else if (nums[i] == 0)
			{
				zeroCnt++;
			}
			else
			{
				res *= nums[i];
				positiveCnt++;
			}
		}

		//当数组仅有 1 个元素且为负数时,最大积为负数
		if (negativeCnt == 1 && zeroCnt == 0 && positiveCnt == 0)
		{
			return nums[0];
		}

		//当数组不包含正数,且负数元素小于等于 1 个时,最大积为 0
		if (negativeCnt <= 1 && positiveCnt == 0)
		{
			return 0;
		}

		//如果乘积为负数,则说明乘积中包含奇数个负数,此时将这个乘积除以最大负数则为最大积
		if (res < 0)
		{
			return res / maxNegative;
		}
		return res;
	}
};
相关推荐
冰红茶兑滴水2 小时前
Linux 线程控制
linux·c++·算法
c语言鹌鹑蛋2 小时前
C++进阶 --- 多继承中的虚表问题
开发语言·c++
MengYiKeNan3 小时前
C++二分函数lower_bound和upper_bound的用法
开发语言·c++·算法
小林熬夜学编程3 小时前
C++第五十一弹---IO流实战:高效文件读写与格式化输出
c语言·开发语言·c++·算法
月夕花晨3743 小时前
C++学习笔记(30)
c++·笔记·学习
蠢蠢的打码3 小时前
8584 循环队列的基本操作
数据结构·c++·算法·链表·图论
不是编程家3 小时前
C++ 第三讲:内存管理
java·开发语言·c++
jianglq4 小时前
C++高性能线性代数库Armadillo入门
c++·线性代数
Lenyiin5 小时前
《 C++ 修炼全景指南:十 》自平衡的艺术:深入了解 AVL 树的核心原理与实现
数据结构·c++·stl
程序猿练习生6 小时前
C++速通LeetCode中等第5题-无重复字符的最长字串
开发语言·c++·leetcode