找到最接近0的数字

2025-01-20

题目:

给你一个长度为 n 的整数数组 nums ,请你返回 nums 中最 接近 0 的数字。如果有多个答案,请你返回它们中的 最大值

示例 1:

输入:nums = [-4,-2,1,4,8]
输出:1
解释:
-4 到 0 的距离为 |-4| = 4 。
-2 到 0 的距离为 |-2| = 2 。
1 到 0 的距离为 |1| = 1 。
4 到 0 的距离为 |4| = 4 。
8 到 0 的距离为 |8| = 8 。
所以,数组中距离 0 最近的数字为 1 。

示例 2:

输入:nums = [2,-1,1]
输出:1
解释:1 和 -1 都是距离 0 最近的数字,所以返回较大值 1 。

提示:

  • 1 <= n <= 1000
  • -105 <= nums[i] <= 105

思路:

简答题,无需多盐

代码:

class Solution {
public:
    int findClosestNumber(vector<int>& nums) {
        int ans = INT_MIN, dis = INT_MAX;
        for (int i = 0; i < nums.size(); i++) {
            if (abs(nums[i]) == dis) {
                ans = max(ans, nums[i]);
            } else if (abs(nums[i]) < dis) {
                ans = nums[i];
                dis = abs(nums[i]);
            }
        }
        return ans;
    }
};