public void CrossTest2()
        {
            var individual1 = new Individual(9, 8, 5, 4, 2, 6, 7, 0, 3, 1);
            var individual2 = new Individual(9, 4, 2, 6, 3, 0, 7, 1, 5, 8);

            for (uint i = 0; i < individual1.Length; i++)
            {
                Debug.Write(individual1[i] - 1);
                Debug.Write(", ");
            }

            Debug.WriteLine(string.Empty);
            for (uint i = 0; i < individual2.Length; i++)
            {
                Debug.Write(individual2[i] - 1);
                Debug.Write(", ");
            }
            Debug.WriteLine(string.Empty);

            var co = new CrossOverOX();

            co.Cross(individual1, individual2);
            CollectionAssert.AreEqual(new uint[] { 9, 8, 2, 4, 3, 6, 7, 0, 5, 1 }, co.Offspring1.ToArray());
            CollectionAssert.AreEqual(new uint[] { 9, 4, 5, 6, 2, 0, 7, 1, 3, 8 }, co.Offspring2.ToArray());
        }
        public void CrossTest5()
        {
            var individual1 = new Individual(8, 4, 7, 3, 6, 2, 5, 1, 9, 0);
            var individual2 = new Individual(0, 1, 2, 3, 4, 5, 6, 7, 8, 9);
            var co          = new CrossOverOX();

            co.Cross(individual1, individual2);
            CollectionAssert.AreEqual(new uint[] { 8, 1, 2, 3, 4, 5, 6, 7, 9, 0 }, co.Offspring1.ToArray());
            CollectionAssert.AreEqual(new uint[] { 0, 4, 7, 3, 6, 2, 5, 1, 8, 9 }, co.Offspring2.ToArray());
        }
        public void CrossTest3()
        {
            var individual1 = new Individual(0, 1, 2, 3, 4, 5, 6);
            var individual2 = new Individual(6, 4, 0, 2, 1, 5, 3);
            var co          = new CrossOverOX();

            co.Cross(individual1, individual2);
            CollectionAssert.AreEqual(new uint[] { 0, 4, 2, 3, 1, 5, 6 }, co.Offspring1.ToArray());
            CollectionAssert.AreEqual(new uint[] { 6, 1, 0, 2, 4, 5, 3 }, co.Offspring2.ToArray());
        }