1
0

78 lines
2.0 KiB
C#

<Query Kind="Statements" />
class C3 { public long X, Y, Z; }
void Main()
{
var input = File.ReadAllLines(Path.Combine(Path.GetDirectoryName(Util.CurrentQueryPath), @"23_input.txt"))
.Where(p => !string.IsNullOrWhiteSpace(p))
.Select(p => new
{
X = long.Parse(p.Split(' ')[0].Substring(5).Split(',')[0].Trim(new[] { ' ', '<', '>', ',' })),
Y = long.Parse(p.Split(' ')[0].Substring(5).Split(',')[1].Trim(new[] { ' ', '<', '>', ',' })),
Z = long.Parse(p.Split(' ')[0].Substring(5).Split(',')[2].Trim(new[] { ' ', '<', '>', ',' })),
R = long.Parse(p.Split(' ')[1].Substring(2).Trim(new[] { ' ', '<', '>', ',' })),
})
.ToList();
var x_min = input.Min(i => i.X);
var x_max = input.Max(i => i.X);
var y_min = input.Min(i => i.Y);
var y_max = input.Max(i => i.Y);
var z_min = input.Min(i => i.Z);
var z_max = input.Max(i => i.Z);
long dist = 1;
for (; dist < x_max - x_min; dist *= 2) ;
long target_count = 0;
C3 best = null;
long? best_val = null;
for (; dist > 0;)
{
target_count = 0;
best = null;
best_val = null;
for (long x = x_min; x <= x_max; x += dist)
{
for (long y = y_min; y <= y_max; y += dist)
{
for (long z = z_min; z <= z_max; z += dist)
{
var count = 0;
foreach (var b in input)
{
var calc = Math.Abs(x - b.X) + Math.Abs(y - b.Y) + Math.Abs(z - b.Z);
if ((calc - b.R) / dist <= 0) count++;
}
if (count > target_count)
{
target_count = count;
best_val = Math.Abs(x) + Math.Abs(y) + Math.Abs(z);
best = new C3 { X = x, Y = y, Z = z };
}
else if (count == target_count)
{
if (Math.Abs(x) + Math.Abs(y) + Math.Abs(z) < best_val)
{
best_val = Math.Abs(x) + Math.Abs(y) + Math.Abs(z);
best = new C3 { X = x, Y = y, Z = z };
}
}
}
}
}
x_min = best.X - dist;
x_max = best.X + dist;
y_min = best.Y - dist;
y_max = best.Y + dist;
z_min = best.Z - dist;
z_max = best.Z + dist;
dist /= 2;
}
best_val.Dump();
}