LeetCode 908. 最小差值 I(C、C++、python)

908. 最小差值 I

题目描述提示帮助提交记录社区讨论阅读解答

随机一题


给定一个整数数组 A,对于每个整数 A[i],我们可以选择任意 x 满足 -K <= x <= K,并将 x 加到 A[i] 中。

在此过程之后,我们得到一些数组 B

返回 B 的最大值和 B 的最小值之间可能存在的最小差值。

示例 1:

输入:A = [1], K = 0
输出:0
解释:B = [1]

示例 2:

输入:A = [0,10], K = 2
输出:6
解释:B = [2,8]

示例 3:

输入:A = [1,3,6], K = 3
输出:0
解释:B = [3,3,3] 或 B = [4,4,4]

提示:

1 <= A.length <= 10000

0 <= A[i] <= 10000

0 <= K <= 10000

C

int smallestRangeI(int* A, int ASize, int K) 
{
    if(ASize<1)
    {
        return 0;
    }
    else
    {
        int M=A[0];
        int m=A[0];
        for(int i=0;i<ASize;i++)
        {
            if(A[i]>M)
            {
                M=A[i];
            }
            if(A[i]<m)
            {
                m=A[i];
            }
        }
        M-=K;
        m+=K;
        if(M<m)
        {
            return 0;
        }
        else
        {
            return M-m;
        }        
    }
}

C++

class Solution {
public:
    int smallestRangeI(vector<int>& A, int K) 
    {
        int M=*max_element(A.begin(),A.end());
        int m=*min_element(A.begin(),A.end());
        M-=K;
        m+=K;
        if(M<m)
        {
            return 0;
        }
        else
        {
            return M-m;
        }
    }
};

python

class Solution:
    def smallestRangeI(self, A, K):
        """
        :type A: List[int]
        :type K: int
        :rtype: int
        """
        M=max(A)
        m=min(A)
        M-=K
        m+=K
        if M<m:
            return 0
        else:
            return M-m
        
        

猜你喜欢

转载自blog.csdn.net/qq_27060423/article/details/82943753
今日推荐