• 入门力扣自学笔记186 C++ (题目编号:1822)


    1822. 数组元素积的符号

    题目:

    已知函数 signFunc(x) 将会根据 x 的正负返回特定值:

    如果 x 是正数,返回 1 。
    如果 x 是负数,返回 -1 。
    如果 x 是等于 0 ,返回 0 。
    给你一个整数数组 nums 。令 product 为数组 nums 中所有元素值的乘积。

    返回 signFunc(product) 。


    示例 1:

    输入:nums = [-1,-2,-3,-4,3,2,1]
    输出:1
    解释:数组中所有值的乘积是 144 ,且 signFunc(144) = 1


    示例 2:

    输入:nums = [1,5,0,2,-3]
    输出:0
    解释:数组中所有值的乘积是 0 ,且 signFunc(0) = 0


    示例 3:

    输入:nums = [-1,1,-1,1,-1]
    输出:-1
    解释:数组中所有值的乘积是 -1 ,且 signFunc(-1) = -1


    提示:

    1 <= nums.length <= 1000
    -100 <= nums[i] <= 100


    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/sign-of-the-product-of-an-array
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


    思路:

    这道题千万不要被题目中的乘积判断正负号所干扰,如果用了乘积,那么最后当结果很大的时候,是无法保存到一个整数类型里面的。

    首先,我们遍历vector,判断每个数字正负号。

    其次,我们用一个整数1,来判断最后乘积的正负号,如果为正则乘1,为负乘-1,如果有0,直接返回0即可。

    最后,我们判断利用的参数sum的正负来输出最后结果即可。


    代码:

    1. class Solution {
    2. public:
    3. int arraySign(vector<int>& nums) {
    4. int sum = 1;
    5. for(int i = 0;i < nums.size();i++)
    6. {
    7. if(nums[i] == 0)
    8. return 0;
    9. else if(nums[i] > 0)
    10. sum *= 1;
    11. else
    12. sum *= -1;
    13. }
    14. return sum > 0 ? 1 : -1;
    15. }
    16. };
  • 相关阅读:
    面试复习题-- JUC
    【esp32】xQueueReceive 函数调试踩坑记录
    浅学Vue
    创建一个Django项目
    【AcWing】3449. 数字根 (数论思维、模拟)
    HarmonyOS开发(一):开发工具起步
    Compose 动画
    神经网络参数相关性测试,神经网络是参数模型吗
    Linux搭建Rabbitmq集群
    PostMan测试接口-----上传文件、导出excel
  • 原文地址:https://blog.csdn.net/DK_Sorhic/article/details/127545534