- 01
 - 02
 - 03
 - 04
 - 05
 - 06
 - 07
 - 08
 - 09
 - 10
 - 11
 - 12
 - 13
 - 14
 - 15
 - 16
 - 17
 - 18
 - 19
 - 20
 
                        Есть односвязный список. Каждый элемент списка содержит указатель на следующий элемент (next). 
Нам известен указатель на первый элемент списка (root). Необходимо без использования каких-либо 
дополнительных структур данных и без изменения структуры элементов списка определить зациклен ли данный список.
Ответ
public static boolean isCycleList(Item root){ 
        Item first = root;     
        while(first.getNext() != null){ 
            Item subFirst = root; 
            do { 
                if (subFirst == first.getNext()) 
                    return true; 
                subFirst = subFirst.getNext(); 
            } 
            while (subFirst != first.getNext());         
            first = first.getNext(); 
        } 
        return false; 
    }
                                 
        
он долбоеб что ли?
Про это уже даже книги пишут Доступная бесплатно глава как раз об этом.
Два изменения одной переменной в одном выражении настораживает сишника и заставляют подсознательно искать УБ.