物联网-c数据结构——2、双向链表

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct student{
    struct student *left;
    struct student *right;
    char data[30];
}STU;
//遍历
void traversal(STU* stu){
    STU* stu_tmp = stu;
    printf("开始遍历\n");
    if(stu == NULL){
        printf("遍历为空\n");
    }
    while(stu_tmp != NULL){
        printf("%s\n",stu_tmp->data);
        stu_tmp = stu_tmp->right;
    }
}

//新增结点
void stuadd(STU** stu){
    STU* stu_tmp = *stu;
    STU* stu_new;
    stu_new = (STU*)malloc(sizeof(STU));
    if(*stu == NULL){
        printf("请输入数据\n");
        scanf("%s",stu_new->data);
        stu_new->left = NULL;
        stu_new->right = NULL;
        *stu = stu_new;
    }else{
        printf("请输入数据\n");
        scanf("%s",stu_new->data);
        while(stu_tmp->right != NULL){
            stu_tmp = stu_tmp->right;
        }
        stu_new->left = stu_tmp;
        stu_new->right = NULL;
        stu_tmp->right = stu_new;
    }
}
//插入
void stuinsert(STU* stu){
    STU* stu_tmp = stu,*stu_new=NULL,*tmp2=NULL;
    char tmp_data[30];
    printf("要在那个数据后插入?\n");
    scanf("%s",tmp_data);
    while((stu_tmp != NULL)&&(strcmp(tmp_data,stu_tmp->data) != 0)){
        stu_tmp = stu_tmp->right;
        printf("ceshi");
    }
    if((stu_tmp == NULL)||(strcmp(tmp_data,stu_tmp->data)!=0)){
        printf("没找到\n");
    }else{
        stu_new = (STU*)malloc(sizeof(STU));
        printf("请输入要插入的数据\n");
        scanf("%s",stu_new->data);
        tmp2 = stu_tmp->right;
        stu_new->right = tmp2;
        stu_new->left = stu_tmp;
        stu_tmp->right = stu_new;
    }
}
//删除
void studelete(STU** stu){
    char tmp_data[30];
    STU *stu_del = *stu;
    printf("请输入要删除的数据");
    scanf("%s",tmp_data);
    while((stu_del!=NULL)&&(strcmp(tmp_data,stu_del->data)!=0)){
        stu_del = stu_del->right;
    }
    if((strcmp(tmp_data,stu_del->data)==0)){
        if((stu_del->left == NULL)&&(stu_del->right == NULL)){
            *stu = NULL;
        }else if(stu_del->left == NULL){//头结点
            *stu = stu_del->right;
            stu_del->right->left = NULL;
        }else if(stu_del->right == NULL){//尾结点
            stu_del->left->right = NULL;
        }else{//中间结点
            stu_del->left->right = stu_del->right;
            stu_del->right->left = stu_del->left;
        }
        printf("以删除\n");
    }else{
        printf("没找到\n");
    }
}
int main()
{
    STU *stu = NULL;
    int item;
    while(1){
        printf("----------------------\n");
        traversal(stu);
        printf("---------0.退出--------\n");
        printf("---------1.新增--------\n");
        printf("---------2.插入--------\n");
        printf("---------3.删除--------\n");
        scanf("%d",&item);
        if(item == 0){
            break;
        }
        switch (item) {
        case 1://新增
            stuadd(&stu);
            break;
        case 2:
            stuinsert(stu);
            break;
        case 3:
            studelete(&stu);
            break;
        default:
            break;
        }
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值