首页 > 其他分享 >【链表操作】前驱和后继

【链表操作】前驱和后继

时间:2024-09-24 22:19:45浏览次数:13  
标签:node head struct 结点 后继 链表 前驱 NULL data

题目描述

设计函数void prevnext(struct node * head, char x);,在以head为头指针的非空链表中,找到数据域值为x的结点,输出该结点的前一个结点和后一个结点的数据域值,如果该结点没有前驱结点(即该结点为第1个结点),则以-1代替,如果该结点没有后继结点(即该结点为尾结点),也以-1代替,如果该结点既是第1个结点也是尾结点(即只有1个结点的链表),则输出2个-1。如果找不到这样的结点,则输出"no node"。

输入

第一行为若干个互不相同的整数,中间用空格分隔,末尾一个整数为-1,以-1前的每个整数为数据域的值创建多个结点,并将这些结点,利用尾插法链接成链表。
第2行为1个整数,表示要查找的结点的数据域的值。

输出

查找到的结点的前驱和后继的数据域值。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

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

void prevnext(struct node *head, int x);
void destroy(struct node* head);
struct node* creatlink();
void traverse(struct node* head);

int main() {
    int c;
    struct node *head;
    head = creatlink();
    scanf("%d", &c);
    prevnext(head, c);
    destroy(head);
    return 0;
}

void prevnext(struct node *head, int x) {
    struct node *prev, *p;
    p = head;
    prev = NULL;
    while (p!= NULL) {
        if (p->data == x) {
            if (prev == NULL) {
                printf("-1 ");
            } else {
                printf("%d ", prev->data);
            }
            if (p->next == NULL) {
                printf("-1");
            } else {
                printf("%d", p->next->data);
            }
            return;
        }
        prev = p;
        p = p->next;
    }
    printf("no node");
}

struct node* creatlink() {
    struct node* head = NULL;
    int data;
    struct node *p, *q;
    while (1) {
        scanf("%d", &data);
        if (data == -1) break;
        p = (struct node *)malloc(sizeof(struct node));
        p->next = NULL;
        p->data = data;
        q = head;
        if (q == NULL) {
            head = p;
        } else {
            while (q->next!= NULL) {
                q = q->next;
            }
            q->next = p;
        }
    }
    return head;
}

void traverse(struct node* head) {
    struct node *p = head;
    while (p!= NULL) {
        printf("%d ", p->data);
        p = p->next;
    }
}

//销毁链表
void destroy(struct node* head) {
    struct node *p;
    while (head!= NULL) {
        p = head;
        head = head->next;
        free(p);
    }
}

标签:node,head,struct,结点,后继,链表,前驱,NULL,data
From: https://blog.csdn.net/2302_80782671/article/details/142470005

相关文章

  • 简单易懂理解:数仓——拉链表
    1.什么是拉链表拉链表就像衣服的拉链一样重要,实用性非常强,使用频率非常高。所谓的拉链,就是历史记录,记录一个事物的开始到结束所变化的所有信息。“拉链表是一种针对数据仓库设计中表存储数据的方式而定义的数据模型,它有点类似于快照,‌它通过记录每个数据项的生效日期和失效......
  • c++实现链表单双环链表
    数据结构链表1.链表实质上是一个结构体,包含数据域和指针域,这两个实际上都是一个变量而已,只不过数据域存放的是节点的数据,指针域存放的是下一个节点的地址2.我们新建一个链表节点的时候通常采取的语句类似于NumList*head=(NumList*)malloc(sizeof(NumList)),要注意,......
  • 数据结构与算法——Java实现 12.习题——合并有序链表
    目录21.合并两个有序链表方法1递归思路方法2迭代思路 完整代码结点类方法 人各有所感,角度不同又怎能感同身受                                                ——24.9.2321.合并两个有序链表将两个......
  • DS循环链表—约瑟夫环
    题目描述N个人坐成一个圆环(编号为1-N),从第S个人开始报数,数到K的人出列,后面的人重新从1开始报数。问最后剩下的人的编号。例如:N=3,K=2,S=1。2号先出列,然后是1号,最后剩下的是3号。要求使用循环链表实现。输入测试数据有多组每组包括3个数N、K、S,表示有N个人,从第S个......