最接近零【难度:1级】:
答案1:
using System;
using System.Linq;
public class Kata
{
public static int? Closest(int[] arr)
{
var ints = arr.Distinct().OrderBy(Math.Abs).Take(2).ToArray();
return ints.First() == ints.Last() * -1 ? (int?) null : ints.First();
}
}
答案2:
using System;
using System.Linq;
public class Kata
{
public static int? Closest(int[] arr)
{
if (arr.Any(p => p == 0)) return 0;
int min = arr.Select(p => Math.Abs(p)).Min();
bool flagPositive = arr.Any(p => p == min);
bool FlagNegative = arr.Any(p => p == - min);
return (flagPositive && FlagNegative) ? new int?() : (flagPositive ? min : - min);
}
}
答案3:
using System;
using System.Linq;
public class Kata
{
public static int? Closest(int[] arr)
{
var nearest = arr.OrderBy(x => Math.Abs((int)x - 0)).First();