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;
	}
};
相关推荐
简单~15 小时前
C++ 函数模板完全指南
c++·函数模板
·心猿意码·15 小时前
C++ 线程安全单例模式的底层源码级解析
c++·单例模式
故事和你9116 小时前
洛谷-入门4-数组3
开发语言·数据结构·c++·算法·动态规划·图论
Yu_Lijing16 小时前
基于C++的《Head First设计模式》笔记——原型模式
c++·笔记·设计模式
玉树临风ives16 小时前
atcoder ABC 451 题解
c++·算法·atcoder
南境十里·墨染春水16 小时前
C++传记 详解单例模式(面向对象)
开发语言·c++·单例模式
扶摇接北海17616 小时前
洛谷:B4488 [语言月赛 202602] 甜品食用
数据结构·c++·算法
cui_ruicheng16 小时前
C++智能指针:从 RAII 到 shared_ptr 源码实现
开发语言·c++
共享家952716 小时前
实现简化的高性能并发内存池
开发语言·数据结构·c++·后端
千里马学框架16 小时前
aospc/c++的native 模块VScode和Clion
android·开发语言·c++·vscode·安卓framework开发·clion·车载开发