單鏈表循環(huán)檢測

  • 單鏈表中的循環(huán)

    • 如果鏈表帶循環(huán),從表頭開始遍歷,最終一定會進(jìn)入鏈表循環(huán)中使得遍歷過程無法適當(dāng)停止。
  • 兩質(zhì)點在同一圓周內(nèi)的運動

    • 假設(shè)兩個質(zhì)點在同一個圓周內(nèi)沿相同方向作無休止的圓周運動,兩質(zhì)點速度恒定且不相同,則不論初始狀態(tài)如何,兩個質(zhì)點總有一刻會撞到一起(實際上他們會無數(shù)次撞到一起)。
  • 代碼實現(xiàn)
    根據(jù)以上兩點,可以寫出判斷單鏈表中是否存在循環(huán)的代碼,如下:

#include <stdio.h>

typedef struct node {
    struct node *next;
    int data;
} node_t;

int check_cycle(node_t *list)
{
    node_t *a = list, *b = list;

    while (b) {
        a = a->next;
        b = b->next;        

        if (!b) {
            break;
        }

        b = b->next;

        if (b == a) {
            return 1;
        }
    }

    return 0;
}

int main()
{
    int i;
    node_t list[100];

    for (i = 0; i < 100; i++) {
        list[i].next = &list[i+1];
    }

    list[99].next = &list[50];
    if (check_cycle(list)) {
        printf("list cycle detected!\n");
    } else {
        printf("list ok!\n");
    }

    list[99].next = NULL;
    if (check_cycle(list)) {
        printf("list cycle detected!\n");
    } else {
        printf("list ok!\n");
    }

    return 0;
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容