Example #1
0
        public WordSet(WordSet w1, WordSet w2)
        {
            if (!w1.IsOrdered() || !w2.IsOrdered())
            {
                throw new Exception("Списки не упорядочены");
            }

            var el1 = w1.First;
            var el2 = w2.First;
            var l3  = new WordSet();

            while (el1 != null && el2 != null)
            {
                if (el1.Info.CompareTo(el2.Info) < 0)
                {
                    l3.AddLast(el1.Info);
                    el1 = el1.Next;
                }
                else
                {
                    l3.AddLast(el2.Info);
                    el2 = el2.Next;
                }
            }
            if (el1 == null)
            {
                while (el2 != null)
                {
                    l3.AddLast(el2.Info);
                    el2 = el2.Next;
                }
            }
            else
            {
                while (el1 != null)
                {
                    l3.AddLast(el1.Info);
                    el1 = el1.Next;
                }
            }
            First = l3.First;
        }
Example #2
0
        public WordSet(WordSet w1, WordSet w2) // Не работает метод override .ToString(), т.к. First после этой оргии равен null
        {
            if (!w1.IsOrdered() || !w2.IsOrdered())
            {
                throw new Exception("Списки не упорядочены");
            }

            var el1 = w1.First;
            var el2 = w2.First;
            var l3  = new SingleLinkedList();

            while (el1 != null && el2 != null)
            {
                if (el1.Info.CompareTo(el2.Info) < 0)
                {
                    l3.AddLast(el1.Info); // n^2 time, would be better memorizing last element
                    el1 = el1.Next;
                }
                else
                {
                    l3.AddLast(el2.Info); // same here
                    el2 = el2.Next;
                }
            }
            if (el1 == null) // can be folded into Elem e = el1 == null ? el2 : el1; while(e != null) {...}
            {
                while (el2 != null)
                {
                    l3.AddLast(el2.Info);
                    el2 = el2.Next;
                }
            }
            else
            {
                while (el1 != null)
                {
                    l3.AddLast(el1.Info);
                    el1 = el1.Next;
                }
            }
        }