Определить все возможные расположения вагонов и локомотива на прямом отрезке железнодорожного пути - C#

Узнай цену своей работы

Формулировка задачи:

Доброго времени суток. У меня такая задача: Локомотив А и вагоны стоят на железнодорожном пути, приведенном ниже, в порядка (слева направо). Локомотив можно произвольно отцеплять и прицеплять с отдельными вагонами, стрелки могут приобретать произвольного положения и локомотив может тянуть или толкать вагон, к которому он прицеплен. Необходимо определить все возможные расположения вагонов и локомотива на прямом отрезке железнодорожного пути. Допускаем у меня есть локомотив А и вагоны B,C,D. Комбинация должна выглядеть так: AB, AC, AD, BAC, BAD, CAB, CAD, DAC, DAB, на сколько я понял. Вот код который я написал. Как сделать так, что бы оно создавало комбинации? Если можно то пожалуйста с объяснением.
 class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Задача про локомотив");
 
            Console.WriteLine("Введите количество вагонов");
 
            int quantity = Convert.ToInt32(Console.ReadLine());

               Console.WriteLine("За локомотив принимаем А");

               string[] alphabet = new string[] { "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z" };
               string[] cars = new string[quantity]; //количество вагонов соответствует количеству элементов в массиве
               string[] depot;//депо
 
               for (int i = 0; i < cars.Length; i++)
               {
                   cars[i] = alphabet[i];
               }

            Console.ReadLine();
        }

Решение задачи: «Определить все возможные расположения вагонов и локомотива на прямом отрезке железнодорожного пути»

textual
Листинг программы
     //init
            Dictionary<int, char> mask = new Dictionary<int, char> {
                {0,'0'},
                {1,'A'},
                {2,'B'},
                {3,'C'},
                {4,'D'},
            };
 
            //data
            int[] values = new int[mask.Count - 1];
            List<string> allValues = new List<string>((int)Math.Pow(mask.Count, mask.Count - 1));
            for (int i = 0, degree = 0; i < Math.Pow(mask.Count, mask.Count - 1); i++)
            {
                string rval = String.Empty;
                foreach (var t in values) rval += mask[t];
                allValues.Add(rval);
                values[degree]++;
 
                for (int j = 0; j < values.Length; j++)
                    if (values[j] == mask.Count)
                    {
                        values[j] = 0;
                        if (j + 1 < values.Length) values[j + 1]++;
                    }
            }
 
            //result
            var result = from _ in (from _ in allValues
                                    where _.Contains('A')
                                    let res = _.Replace("0", String.Empty)
                                    where res.Distinct().Count() == res.Count()
                                    select res).Distinct()
                         orderby _
                         select _;
            foreach (var r in result) Console.WriteLine(r);

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

9   голосов , оценка 4 из 5
Похожие ответы