[Swift]LeetCode908. 最小差值 I | Smallest Range I
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公众号:山青咏芝(shanqingyongzhi)
➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址: https://www.cnblogs.com/strengthen/p/10610215.html
➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
Given an array A
of integers, for each integer A[i]
we may choose any x
with -K <= x <= K
, and add x
to A[i]
.
After this process, we have some array B
.
Return the smallest possible difference between the maximum value of B
and the minimum value of B
.
Example 1:
Input: A = [1], K = 0
Output: 0
Explanation: B = [1]
Example 2:
Input: A = [0,10], K = 2
Output: 6
Explanation: B = [2,8]
Example 3:
Input: A = [1,3,6], K = 3
Output: 0
Explanation: B = [3,3,3] or B = [4,4,4]
Note:
1 <= A.length <= 10000
0 <= A[i] <= 10000
0 <= K <= 10000
给定一个整数数组 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
16ms
1 class Solution { 2 func smallestRangeI(_ A: [Int], _ K: Int) -> Int { 3 var smallest = A[0], largest = A[0] 4 for num in A { 5 if num < smallest { smallest = num } 6 else if num > largest { largest = num } 7 } 8 let diff = largest - smallest 9 if diff <= 2 * K { 10 return 0 11 } else { 12 return diff - 2 * K 13 } 14 } 15 }
120ms
1 class Solution { 2 func smallestRangeI(_ A: [Int], _ K: Int) -> Int { 3 var ma = Int.min 4 var mi = Int.max 5 for num in A { 6 ma = max(ma,num) 7 mi = min(mi,num) 8 } 9 return (ma-mi) <= 2*K ? 0 : ma-mi-2*K 10 } 11 }
124ms
1 class Solution { 2 func smallestRangeI(_ A: [Int], _ K: Int) -> Int { 3 guard A.count > 1 else { 4 return 0 5 } 6 let mx = A.max()! 7 let mi = A.min()! 8 return max(0, mx - mi - K * 2) 9 } 10 }
1 class Solution { 2 func smallestRangeI(_ A: [Int], _ K: Int) -> Int { 3 var A = A.sorted() 4 guard let first = A.first, let last = A.last else { 5 return 0 6 } 7 return (last - first - 2 * K) > 0 ? (last - first - 2 * K) : 0 8 } 9 }
Runtime: 140 ms
1 class Solution { 2 //抓住最大值与最大值之间的重点关系, 3 //因为其他数可以通过加减K靠近极值 4 func smallestRangeI(_ A: [Int], _ K: Int) -> Int { 5 //如果数组只有一个数字则返回0 6 if A.count==1{return 0} 7 //初始化最大值 8 var maxNum:Int = A[0] 9 //初始化最小值 10 var minNum:Int = A[0] 11 //遍历数组 12 for i in 0..<A.count 13 { 14 if A[i] > maxNum 15 { 16 maxNum = A[i] 17 } 18 if A[i] < minNum 19 { 20 minNum = A[i] 21 } 22 } 23 if minNum+2*K>=maxNum 24 { 25 return 0 26 } 27 else 28 { 29 return maxNum-minNum-2*K 30 } 31 } 32 }
148ms
1 class Solution { 2 func smallestRangeI(_ A: [Int], _ K: Int) -> Int { 3 return max(0, (A.max() ?? 0) - (A.min() ?? 0) - 2*K) 4 } 5 }
180ms
1 class Solution { 2 func smallestRangeI(_ A: [Int], _ K: Int) -> Int { 3 guard A.count != 1 else { 4 return 0 5 } 6 var max = A[0] 7 var min = A[0] 8 for i in A { 9 max = i > max ? i : max 10 min = i < min ? i : min 11 } 12 var diff = max - min 13 return abs(K * 2) >= diff ? 0 : diff - abs(K * 2) 14 } 15 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了