单向循环链表

单向循环链表

1.定义结点

#define ERROR 0 #define TRUE 1 #define FALSE 0 #define OK 1 #define MAXSIZE 20 /* 存储空间初始分配量 */ typedef int Status;/* Status是函数的类型,其值是函数结果状态代码,如OK等 */ typedef int ElemType;/* ElemType类型根据实际情况而定,这里假设为int */

//定义结点 typedef struct Node{     ElemType data;//数据域     struct Node *next;//指针域 }Node;

typedef struct Node *LinkList;

2.创建

2种情况:① 第一次开始创建; ②已经创建,往里面新增数据

 1. 判断是否第一次创建链表

 YES->创建一个新结点,并使得新结点的next 指向自身; (*L)->next = (*L);

 NO-> 找链表尾结点,将尾结点的next = 新结点. 新结点的next = (*L);

创建方法1

Status CreateList(LinkList *L) {

    intvalue =0;

    printf("输入节点的值,输入0结束\n");

    LinkListtemp =NULL;

    LinkListtarget =NULL;

    while(1) {

        //输入要插入的数据

        scanf("%d",&value);

        if(value ==0) {

            break;

        }

        //如果输入的链表是空。则创建一个新的节点,使其next指针指向自己  (*head)->next=*head;

        if(*L ==NULL) {

            *L = (LinkList)malloc(sizeof(Node));

            if(!L) {

                exit(0);

            }else{

                //给数据域赋值

                (*L)->data= value;

                //将指针域指向自己

                (*L)->next= *L;

            }

        }else{

       //输入的链表不是空的,寻找链表的尾节点,使尾节点的next=新节点。新节点的next指向头节点

            //找到尾结点


            for(target = *L; target->next!= *L; target = target->next) {

                //target先指向首元结点

                //判断target->next是否指向首元结点(结束的标志)

                //target不是尾结点,则target->next指向下一个结点

            }

            //找到尾结点后

            temp = (LinkList)malloc(sizeof(Node));

            //

            temp->data= value;

            //新结点的next指向首元结点

            temp->next= *L;

            //将target->next 指向新结点

            target->next= temp;

        }

    }


    returnOK;

}

创建方法2

Status CreateList2(LinkList *L) {

    intvalue =0;

    printf("输入节点的值,输入0结束\n");


    LinkListtemp =NULL;

    //记录尾结点

    LinkListr =NULL;

    while(1) {

        //输入要插入的数据

        scanf("%d",&value);

        if(value ==0) {

            break;

        }

        //如果输入的链表是空。则创建一个新的节点,使其next指针指向自己  (*head)->next=*head;

        if(*L ==NULL) {

            *L = (LinkList)malloc(sizeof(Node));

            if(!L) {

                exit(0);

            }else{

                //给数据域赋值

                (*L)->data= value;

                //将指针域指向自己

                (*L)->next= *L;

                //指向尾结点

                r = *L;

            }

        }else{

            //生成新结点

            temp = (LinkList)malloc(sizeof(Node));

            //

            temp->data= value;

            //新结点的next指向首元结点

            temp->next= *L;

            //将target->next 指向新结点

            r->next= temp;

            //记录尾结节

            r = temp;

        }

    }


    returnOK;

}

遍历

单向循环链表的遍历最好用do while,因为头结点就有值

void TraversalList(LinkList L){

    //如果是空

    if(L ==NULL) {

        printf("打印的链表为空!\n");

        return;

    }else{

        inti =1;

        LinkListtemp;

        temp = L;

        do{

            printf("链表第%d个值=%d\n",i,temp->data);

            temp = temp->next;

            i++;

        }while(temp != L);//当temp是首元节点时结束循环

        printf("链表遍历完成\n");

    }


}

循环链表插入数据

StatusListInsert(LinkList*L,intindex,intvalue){

    if(*L ==NULL|| index <1) {

        returnERROR;

    }

    //1. 创建新结点temp,并判断是否创建成功,成功则赋值,否则返回ERROR;

    LinkListnewNode = (LinkList)malloc(sizeof(Node));

    newNode->data= value;

    //

    LinkListtarget =NULL;


    if(newNode ==NULL) {

        returnERROR;

    }

    if(index ==1) {

        //如果是插入首元结点

        //找到尾结点

        for(target = *L; target->next!= *L; target = target->next) {


        }

        //新结点作为首元结点

        newNode->next= *L;

        //尾结点指向新结点

        target->next= newNode;

        //首地址指向新结点

        *L = newNode;

    }else{

        //找到目标结点的上一个结点

        inti=0;

        //先指向首元结点

        target = *L;

        for(i=1; i!= index-1; i++) {


            if(target->next== *L) {

                //找到尾结点,说明尾结点就是目标结点,结束

                break;

            }

            //下一个结点

            target = target->next;

        }

        //结点的next指向目标结点的next

        newNode->next= target->next;

        //目标结点的next指向新结点

        target->next= newNode;

    }

    returnOK;

}

循环链表删除元素

StatusLinkListDelete(LinkList*L,intindex){

    if(*L ==NULL|| index <=0) {

        returnERROR;

    }

    //指向首元结点

    LinkListtemp = *L;

    LinkListtarget ;

    if(index ==1) {

        if((*L)->next== (*L)) {

            free(temp);

            *L =NULL;

            returnOK;

        }

        //删除首元结点

        //找到尾结点

        for(target = *L; target->next!= *L; target = target->next) {


        }

        //首下一个结点改为首元结点

        *L = (*L)->next;

        //将尾结点指向新的首元结点

        target->next= *L;

        //释放删除的结点

        free(temp);

    }else{

        //找到目标结点的上一个结点

        inti=0;

        target = *L;

        for(i=1; i!=index-1; i++) {

            if(target->next== *L) {

                //找到尾结点,说明尾结点就是目标结点,结束

                break;

            }

            target = target->next;

        }

        //如果找到目标结点是尾结点,则说明越界了

        if(target->next== *L) {

            printf("越界了\n");

            returnERROR;

        }

        //记录要删除的结点

        temp = target->next;

        //目标结点指向要删除结点的下一个结点

        target->next= temp->next;

        free(temp);

    }

    returnOK;

}

循环链表的查询

ElemType findValue(LinkList L,int index){

    if(L ==NULL|| index <=0) {

        returnERROR;

    }


    intvalue =0;

    //指向首元结点

    LinkListtarget = L;

    inti=0;

    for(i=1; i != index; i++) {


        if(target->next== L) {

            //找到尾结点了,越界了

            break;

        }

        target = target ->next;

    }

    value = target->data;

    returnvalue;

}

最后是调用

intmain(intargc,constchar* argv[]) {


    printf("单向循环链表\n");

    LinkListhead;

    intindex,value;

    CreateList2(&head);


    TraversalList(head);


    printf("输入要插入的位置和数据用空格隔开1:");

    scanf("%d %d",&index,&value);

    ListInsert(&head,index,value);

    TraversalList(head);


    printf("输入要插入的位置和数据用空格隔开2:");

    scanf("%d %d",&index,&value);

    ListInsert(&head,index,value);

    TraversalList(head);


    printf("输入要插入的位置和数据用空格隔开3:");

    scanf("%d %d",&index,&value);

    ListInsert(&head,index,value);

    TraversalList(head);


    printf("输入要删除的位置:");

    scanf("%d",&index);

    LinkListDelete(&head,index);

    TraversalList(head);


    printf("输入要查找的位置1:");

    scanf("%d",&index);

    value =findValue(head, index);

    printf("查询到的数据 = %d\n",value);

    printf("输入要查找的位置2:");

    scanf("%d",&index);

    value =findValue(head, index);

    printf("查询到的数据 = %d\n",value);


    printf("输入要查找的位置3:");

    scanf("%d",&index);

    value =findValue(head, index);

    printf("查询到的数据 = %d\n",value);

    return0;

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容