【leetcode详解】一个小组的最大实力值【中等】

实战总结:

//for循环使用注意: 

括号内的条件是循环的结束条件,相当于break,会直接导致循环结束!

要实现continue的条件只能写在循环内部

//一个错误写法:      

if( j < 0 || nums[ j ] <= 0 ), 因为'||'两侧的条件都会判断,j<0时会导致越界


题面

思路分析

核心是分类讨论思想, 难点主要在于提升代码应对不同情况的鲁棒性。

  • 先排序
  • 接着一对一对地考虑负数(因为负负才得正)
  • 然后一个一个地乘进正数
    • 整个过程中用flag标记, 防止 nums = [ -1, 0, ..., 0 ] 的情况出现, 此时应返回 0;

代码实现:

class Solution {
public:
    long long maxStrength(vector<int>& nums) {
        int sz = nums.size();
        if(sz == 1) return nums[0];//特殊情况处理
		sort(nums.begin(), nums.end());
        int i=1, flag=0;//flag用来排除结果为0的情况
        long long res=1;   
        for(; i<sz && nums[i] < 0; i+=2)
        {
            flag = 1;
			res *= (nums[i]*nums[i-1]);
		}
		//for循环使用注意: 
		//括号内的条件是循环的结束条件,相当于break,会直接导致循环结束
		//错误写法 if(j < 0 || nums[j] <= 0), 因为'||'两侧的条件都会判断,j<0时会导致越界
		for(int j=i-1; j < sz ; j++)
		{
            if(j < 0) continue;
            else if(nums[j] <= 0) continue;
            flag = 1;
			res *= nums[j];
		}
        if(flag == 1) return res;
		return 0;
    }
};

~希望对你有启发!~

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值