竞赛题-6283. 正整数和负整数的最大计数

2023-01-07  本文已影响0人  程序员小2

题目:

给你一个按 非递减顺序 排列的数组 nums ,返回正整数数目和负整数数目中的最大值。

换句话讲,如果 nums 中正整数的数目是 pos ,而负整数的数目是 neg ,返回 pos 和 neg二者中的最大值。
注意:0 既不是正整数也不是负整数。

示例 1:

输入:nums = [-2,-1,-1,1,2,3]
输出:3
解释:共有 3 个正整数和 3 个负整数。计数得到的最大值是 3 。
示例 2:

输入:nums = [-3,-2,-1,0,0,1,2]
输出:3
解释:共有 2 个正整数和 3 个负整数。计数得到的最大值是 3 。
示例 3:

输入:nums = [5,20,66,1314]
输出:4
解释:共有 4 个正整数和 0 个负整数。计数得到的最大值是 4 。

提示:

1 <= nums.length <= 2000
-2000 <= nums[i] <= 2000
nums 按 非递减顺序 排列。

java代码:

class Solution {
    public int maximumCount(int[] nums) {
        int len = nums.length;
        if(nums[0]>0 || nums[len-1]<0) {
            return len;
        }
        
        int pos =0;
        int neg = 0;
        
        for(int i=0;i<len;i++) {
            if(nums[i]<0) {
                neg++;
            }else if(nums[i]>0) {
                pos = len -i;
                break;
            }
        }
        
        return Math.max(neg, pos);
    }
}
上一篇 下一篇

猜你喜欢

热点阅读