Image.cs 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. namespace Day13;
  2. public class Image
  3. {
  4. private readonly IList<string> _lines;
  5. public Image(IList<string> lines)
  6. {
  7. _lines = lines;
  8. }
  9. public void Print()
  10. {
  11. foreach (var line in _lines)
  12. {
  13. Console.WriteLine(line);
  14. }
  15. }
  16. public int FindFold()
  17. {
  18. var map = new Dictionary<string, List<int>>();
  19. for (var i = 0; i < _lines.Count; i++)
  20. {
  21. if (!map.ContainsKey(_lines[i]))
  22. {
  23. map[_lines[i]] = new List<int>();
  24. }
  25. map[_lines[i]].Add(i + 1);
  26. }
  27. var centers = map
  28. .Where(kvp => kvp.Value.Count >= 2)
  29. .SelectMany(kvp =>
  30. Pairs(kvp.Value.Count)
  31. .Select(p =>
  32. new AxisInfo(
  33. (kvp.Value[p.Left] + kvp.Value[p.Right]) / 2,
  34. Math.Min(kvp.Value[p.Left], kvp.Value[p.Right]),
  35. Math.Max(kvp.Value[p.Left], kvp.Value[p.Right]))
  36. )
  37. .Where(info => (info.Upper - info.Lower) % 2 == 1)
  38. ).GroupBy(info => info.Center);
  39. foreach (var group in centers)
  40. {
  41. var toBorder = Math.Min(group.Key, _lines.Count - group.Key);
  42. if (group.Count() == toBorder)
  43. {
  44. return group.Key;
  45. }
  46. }
  47. return -1;
  48. }
  49. public Image Rotate()
  50. {
  51. return new Image(Enumerable.Range(0, _lines[0].Length)
  52. .Select(i => new string(_lines.Select(x => x[i]).ToArray()))
  53. .ToList());
  54. }
  55. private static IEnumerable<(int Left, int Right)> Pairs(int n)
  56. {
  57. for (var i = 0; i < n - 1; i++)
  58. {
  59. for (var j = i + 1; j < n; j++)
  60. {
  61. yield return (i, j);
  62. }
  63. }
  64. }
  65. private record AxisInfo(int Center, int Lower, int Upper);
  66. }