leetcode2529-正整数和负整数的最大计数

这篇具有很好参考价值的文章主要介绍了leetcode2529-正整数和负整数的最大计数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

题目:

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

  • 换句话讲,如果 nums 中正整数的数目是 pos ,而负整数的数目是 neg ,返回 posneg二者中的最大值。

注意: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 。

分析:

这道题目要求分析一个非递减顺序排列的数组nums,并返回数组中正整数和负整数的最大数量。这里有几个关键点需要注意:

  1. 非递减顺序排列:这意味着数组中的元素从左到右是不减的,即每个后续元素都不小于其前一个元素。这个特性对于解题不是直接必要的,但它告诉我们数组是有序的。

  2. 正整数和负整数的计数:题目要求我们找出正整数和负整数的数量,并返回这两个数中的最大值。这里有一个隐含的信息是0既不算正数也不算负数,所以在计数时应该忽略0。

  3. 返回的是数量的最大值:我们不需要关心具体的正数或负数是什么,只需要知道它们的数量。

解题思路

基于上述分析,我们可以得出一个直接且有效的解题方法:

  • 遍历数组:由于数组是非递减顺序排列的,我们可以简单地遍历一遍数组,对正整数和负整数分别计数。

  • 计数正负整数:对于数组中的每个元素,如果它大于0,我们就增加正整数的计数;如果它小于0,我们就增加负整数的计数。遇到0时,我们不做任何操作。

  • 比较并返回最大值:遍历完成后,我们比较正整数和负整数的数量,返回较大的那个。文章来源地址https://www.toymoban.com/news/detail-850702.html

代码实现

class Solution {
public:
    int maximumCount(vector<int>& nums) {
        int posCount = 0; // 正整数的数量
        int negCount = 0; // 负整数的数量
        
        // 遍历数组,统计正负整数的数量
        for (int num : nums) {
            if (num > 0) {
                posCount++;
            } else if (num < 0) {
                negCount++;
            }
            // 注意:0不计入任何一方
        }
        
        // 返回正负整数数量的最大值
        return max(posCount, negCount);
    }
};

到了这里,关于leetcode2529-正整数和负整数的最大计数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 力扣(leetcode)第696题计数二进制字串(Python)

    题目链接:696.计数二进制字串 给定一个字符串 s,统计并返回具有相同数量 0 和 1 的非空(连续)子字符串的数量,并且这些子字符串中的所有 0 和所有 1 都是成组连续的。 重复出现(不同位置)的子串也要统计它们出现的次数。 示例 1: 输入:s = “00110011” 输出:6 解释

    2024年01月20日
    浏览(26)
  • 【LeetCode力扣】189 53 轮转数组 | 最大子数组和

    目录 1、189. 轮转数组 1.1、题目介绍 1.2、解题思路 2、53. 最大子数组和 2.1、题目介绍 2.2、解题思路   原题链接: 189. 轮转数组 - 力扣(LeetCode) ​ 示例 1: 输入: nums = [1,2,3,4,5,6,7], k = 3 输出: [5,6,7,1,2,3,4] 解释: 向右轮转 1 步: [7,1,2,3,4,5,6] 向右轮转 2 步: [6,7,1,2,3,4,5] 向右轮转

    2024年02月08日
    浏览(27)
  • Leetcode—2530.执行K次操作后的最大分数【中等】(C语言向上取整数学公式)

    参考了这篇文章 有人肯定会问,这个向上取整为什么是这样来的。接下来我简单讲解一下。 数学式: x y 数学式:frac{x}{y} 数学式: y x ​ 有以下两种情况 x能整除y,则 x y frac{x}{y} y x ​ 就是向上取整和向下取整结果一致的情况,不需要额外转换。也就是说 x y frac{x}{y} y

    2024年02月07日
    浏览(39)
  • C语言实例:输出八进制,十进制,十六进制,指定位数整数,带符号整数,科学计数法表示的整数

    直接使用printf函数输出整数即可,例如: 输出结果为: %d是printf函数的格式控制符,用于输出整数。在printf函数中,%d会被替换成一个整数变量的值。例如,printf(“%d”, num)中%d将被num的值替换,从而输出num的值作为整数。 使用printf函数的格式控制符可以输出指定位数的整数

    2024年02月08日
    浏览(43)
  • 力扣:罗马转整数

    class 定义了一个类Solution,这个类里面有有私有成员和共有成员 首先定义了一个私有成员,我也不知道为什么需要这个私有成员,unordered_mapunordered_mapchar, int用法再去搜搜。 注意两个头文件不要加h。 代码整体的思路就是定义一个类,这个类首先定义了私有对象一个map的字符到

    2024年02月06日
    浏览(33)
  • 力扣 面试题 05.06. 整数转换

    思路: 牵扯到二进制数,基本上要考虑 位运算符 ,相关知识可以见 之前做过类似的题目,大致思路就是 先用按位异或^找出不同位 ,再用 n(n-1)计算出不同位的个数 ,但是这道题有个小坑,就是极限了话, n刚好为int类型的最小值(即二进制数为1000……0000),此时n-1就

    2024年02月22日
    浏览(27)
  • 整数拆分(力扣)动态规划 JAVA

    给定一个正整数 n ,将其拆分为 k 个 正整数 的和( k = 2 ),并使这些整数的乘积最大化。 返回 你可以获得的最大乘积 。 示例 1: 输入: n = 2 输出: 1 解释: 2 = 1 + 1, 1 × 1 = 1。 示例 2: 输入: n = 10 输出: 36 解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。 提示: 2 = n = 58 里程碑意义 解题思路:

    2024年02月17日
    浏览(33)
  • 【力扣】343. 整数拆分 <动态规划、数学>

    给定一个正整数 n ,将其拆分为 k 个 正整数 的和( k = 2 ),并使这些整数的乘积最大化。返回可以获得的最大乘积 。 示例 1: 输入: n = 2 输出: 1 解释: 2 = 1 + 1, 1 × 1 = 1。 示例 2: 输入: n = 10 输出: 36 解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。 提示: 2 = n = 58 动态规划 确定 dp 数组以及下

    2024年02月09日
    浏览(33)
  • 【力扣刷题】整数拆分(动态规划)

    个人简历: 全栈领域新星博主, 万粉博主、 帮助初学者入门,记录自己的学习过程 个人主页:天寒雨落的博客_CSDN博客-C,CSDN竞赛,python领域博主 热门专栏:初学者入门C语言_天寒雨落的博客-CSDN博客   目录 动态规划 整数拆分 题目 思路 代码 执行结果 其基本思想是将待求解

    2024年02月03日
    浏览(31)
  • 整数替换(力扣)HashMap + 递归 JAVA

    给定一个正整数 n ,你可以做如下操作: 如果 n 是偶数,则用 n / 2替换 n 。 如果 n 是奇数,则可以用 n + 1或n - 1替换 n 。 返回 n 变为 1 所需的 最小替换次数 。 示例 1: 输入:n = 8 输出:3 解释:8 - 4 - 2 - 1 示例 2: 输入:n = 7 输出:4 解释:7 - 8 - 4 - 2 - 1 或 7 - 6 - 3 - 2 - 1 示

    2024年02月15日
    浏览(23)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包