MinDistrib.cs 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. namespace MathModTasks
  7. {
  8. /// <summary>
  9. /// Осуществляет распределение в транспортной задаче по минимальному элементу
  10. /// </summary>
  11. class MinDistrib
  12. {
  13. int[] whoGive, whoGet;
  14. Element[,] mainData1;
  15. int m, n;
  16. public int CountNotNullElement = 0;
  17. /// <summary>
  18. /// Задает локальные переменные для вычисления
  19. /// </summary>
  20. /// <param name="mainData">Матрица с затратами на перевозку</param>
  21. /// <param name="whoGive">Массив поставщиков</param>
  22. /// <param name="whoGet">Массив покупателей</param>
  23. /// <param name="m">Количество столбцов</param>
  24. /// <param name="n">Количество строк</param>
  25. public MinDistrib(Element[,] mainData, int[] whoGive, int[] whoGet, int m, int n)
  26. {
  27. this.whoGive = whoGive;
  28. this.whoGet = whoGet;
  29. this.m = m;
  30. this.n = n;
  31. mainData1 = new Element[n, m];
  32. for (int i = 0; i < n; i++)
  33. for (int j = 0; j < m; j++)
  34. mainData1[i, j].Value = mainData[i, j].Value;
  35. }
  36. /// <summary>
  37. /// Осуществляет распределение в транспортной задаче по минимальному элементу
  38. /// </summary>
  39. /// <param name="distrMatric">Матрица для распределения поставок</param>
  40. /// <returns></returns>
  41. public int MinDistribute(ref Element[,] distrMatric)
  42. {
  43. int[] min = FindMin();
  44. int i = 0, j = 0;
  45. while (min[0] != 0)
  46. {
  47. try
  48. {
  49. //если элемент массива поставщиков равен нулю, i прибавляется, и ищется новый минимум в матрице
  50. if (whoGive[min[1]] == 0) { i++; min = FindMin(); }
  51. //если элемент массива покупателей равен нулю, j прибавляется, и ищется новый минимум в матрице
  52. else if (whoGet[min[2]] == 0) { j++; min = FindMin(); }
  53. //если элементы массива поставщиков и покупателей равны нулю, i и j прибавляются, и ищется новый минимум в матрице
  54. else if (whoGive[min[1]] == 0 && whoGet[min[2]] == 0) { i++; j++; min = FindMin(); }
  55. //в остальных случаях вычисляется распеределение поставок
  56. else
  57. {
  58. //из массива поставщиков и покупателей сравнивается, какой элемент меньше, он и будет добавлен как поставка
  59. distrMatric[min[1], min[2]].Delivery = FindMinElement(whoGive[min[1]], whoGet[min[2]]);
  60. whoGive[min[1]] -= distrMatric[min[1], min[2]].Delivery;
  61. whoGet[min[2]] -= distrMatric[min[1], min[2]].Delivery;
  62. min = FindMin();
  63. //переменная, которая записывает количество поставок (не пустых ячеек доставки)
  64. CountNotNullElement++;
  65. }
  66. }
  67. catch
  68. {
  69. }
  70. }
  71. return CountNotNullElement;
  72. }
  73. /// <summary>
  74. /// Нахождение минимального элемента с обнулением матрицы затрат (чтобы не использовалась при следующем нахождении минимума)
  75. /// </summary>
  76. /// <returns></returns>
  77. public int[] FindMin()
  78. {
  79. int min = mainData1[0, 0].Value;
  80. int[] minData = new int[3];
  81. for (int i = 0; i < n; i++)
  82. for (int j = 0; j < m; j++)
  83. {
  84. if (min >= mainData1[i, j].Value && mainData1[i, j].Value != 0 && min != 0)
  85. {
  86. min = mainData1[i, j].Value;
  87. minData[0] = min;
  88. minData[1] = i;
  89. minData[2] = j;
  90. }
  91. else if (min == 0 && min < mainData1[i, j].Value)
  92. {
  93. min = mainData1[i, j].Value;
  94. minData[0] = min;
  95. minData[1] = i;
  96. minData[2] = j;
  97. }
  98. }
  99. //использованная ячейка с минимальными затратами обнуляется, чтобы она пропускалась при нахождении минимума
  100. mainData1[minData[1], minData[2]].Value = 0;
  101. return minData;
  102. }
  103. /// <summary>
  104. /// Нахождение минимума среди чисел a и b
  105. /// </summary>
  106. /// <param name="a">число</param>
  107. /// <param name="b">число</param>
  108. /// <returns></returns>
  109. static int FindMinElement(int a, int b)
  110. {
  111. if (a > b) return b;
  112. else if (a == b) { return a; }
  113. else return a;
  114. }
  115. }
  116. }