解题思路:

注意事项:

参考代码:

#include<stdio.h>

#include<stdlib.h>

#include<string.h>


typedef struct node

{

    int data;

    struct node *prev;

    struct node *next;

}listnode;


listnode *creatnode();

void printfnode(listnode *head);

void insertnode(listnode *head,int location,int value);

void deletenode(listnode *head,int location);

void freenode(listnode *head);


int main()

{

int a,b,c;

listnode *firstnode=creatnode();

while(scanf("%d",&a)!=EOF)

{

    switch(a)

    {

        case 0:printfnode(firstnode);break;

        case 1:scanf("%d %d",&b,&c);insertnode(firstnode,b,c);break;

        case 2:scanf("%d",&b);deletenode(firstnode,b);break;

        default:break;

    }

}

return 0;

}


listnode *creatnode()

{

    listnode *head;

    head=(listnode *)malloc(sizeof(listnode));

    if(head==NULL)

    {

        perror("malloc fail");

        exit(0);

    }

    head->prev=head;

    head->next=head;

    return head;

}


void printfnode(listnode *head)

{

    listnode *temp=head->next;

    while(temp!=head)

    {

        printf("%d ",temp->data);

        temp=temp->next;

    }

    printf("\n");

}


void insertnode(listnode *head,int location,int value)

{

    listnode *temp=head;

    listnode *middle=malloc(sizeof(listnode));

    if(middle==NULL)

    {

        perror("malloc fail");

        exit(0);

    }

    middle->data=value;

    for(int i=1;i<location;i++)

    {

        temp=temp->next;

    }

    middle->next=temp->next;

    temp->next->prev=middle;

    temp->next=middle;

    middle->prev=temp;

}


void deletenode(listnode *head,int location)

{

    listnode *temp=head;

    for(int i=1;i<=location;i++)

    {

        temp=temp->next;

    }

    temp->prev->next=temp->next;

    temp->next->prev=temp->prev;

    free(temp);

}


void freenode(listnode *head)

{

    listnode *curr=head;

    while(curr!=NULL)

    {

        listnode *temp=curr->next;

        free(curr);

        curr=temp;

    }

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论