#include <stdbool.h> /** * struct ListNode { * int val; * struct ListNode *next; * }; */ /** * * @param head ListNode类 * @return bool布尔型 */ bool hasCycle(struct ListNode* head ) { //思路 //使用快慢指针,若二者相遇,则表示有环 struct ListNode* fast = head; struct ListNode* slow = head; if (head == NULL) { return false; } while ((slow != NULL) && (fast != NULL) && (fast->next != NULL)) { slow = slow->next; fast = fast->next->next; if (slow == fast) { return true; } } return false; }