908. Smallest Range I
Вам дан entero arreglo nums и entero k. За одну операцию вы можете выбрать любой индекс i, где 0 <= i < nums.length, и изменить nums[i] на nums[i] + x, где x - entero из диапазона [-k, k]. Эту операцию можно применять не более одного раза для каждого индекса i. Оценка nums - это разница между максимальным и минимальным elementами в nums. return минимальную оценку nums после Applications указанной операции не более одного раза для каждого индекса в нем.
Ejemplo:
Input: nums = [1], k = 0
Output: 0
C# solución
coincidente/originalpublic class Solution {
public int SmallestRangeI(int[] nums, int k) {
int minVal = int.MaxValue;
int maxVal = int.MinValue;
foreach (int num in nums) {
if (num < minVal) minVal = num;
if (num > maxVal) maxVal = num;
}
return Math.Max(0, (maxVal - k) - (minVal + k));
}
}
C++ solución
borrador automático, revisar antes de enviar#include <bits/stdc++.h>
using namespace std;
// Auto-generated C++ draft from the C# solution. Review containers, LINQ and helper types before submit.
class Solution {
public:
public int SmallestRangeI(vector<int>& nums, int k) {
int minVal = int.MaxValue;
int maxVal = int.MinValue;
foreach (int num in nums) {
if (num < minVal) minVal = num;
if (num > maxVal) maxVal = num;
}
return max(0, (maxVal - k) - (minVal + k));
}
}
Java solución
coincidente/originalclass Solution {
public int smallestRangeI(int[] nums, int k) {
int minVal = Integer.MAX_VALUE;
int maxVal = Integer.MIN_VALUE;
for (int num : nums) {
if (num < minVal) minVal = num;
if (num > maxVal) maxVal = num;
}
return Math.max(0, (maxVal - k) - (minVal + k));
}
}
Algorithm
1⃣find минимальное и максимальное значения arregloа nums.
2⃣Рассчитать потенциальные новые минимальные и максимальные значения после Applications операции.
3⃣Вычислить минимальную оценку, сравнивая разницу между всеми возможными новыми минимальными и максимальными значениями.
😎
Vacantes para esta tarea
Se muestran vacantes activas con etiquetas coincidentes.