<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();
}