单链表逆置

西安电子科技大学数据结构与算法上机实验——单链表逆置

先通过一次遍历所有结点,判断其个数值,进而得到中间结点的位置,定义两个工作指针一个从前向后开始移动,另一个从最后像前面逆向移动,移动的过程中进行循环交换中间结点对称两侧的节点数值,不改变原结点的连接情况

#include<malloc.h>
#include<stdio.h>

# define LEN sizeof(struct linklist)

struct linklist {
    int num;
    struct linklist *next;
};

struct linklist *create();

void print(struct linklist *);

void invert(struct linklist *);

int main(void) {
    struct linklist *head;
    printf("***************请创建链表*****************\n");
    head = create();
    printf("***************输出原链表*****************\n");
    print(head);
    invert(head);//调用单链表逆置的函数
    printf("************输出逆置后的链表**************\n");
    print(head);
    return 0;
}

struct linklist *create() {
    struct linklist *p, *q, *head = NULL;
    p = q = (struct linklist *) malloc(LEN);
    scanf("%d", &p->num);
    while (p->num != 0) {
        if (head == NULL) {
            head = p;
        } else {
            q->next = p;
        }
        q = p;
        p = (struct linklist *) malloc(LEN);
        scanf("%d", &p->num);
    }
    q->next = 0;
    free(p);
    return head;
}

void print(struct linklist *const head) {
    struct linklist *p = head;
    do {
        printf("%d ", p->num);
        p = p->next;
    } while (p != NULL);
    printf("\n");
}

void invert(struct linklist *const head) {
    int i, j, t, m, n = 0;
    struct linklist *p = head, *q;
    while (p != NULL) {
        p = p->next;
        n++;
    }
    p = head;
    m = n / 2;
    for (i = 0; i < m; i++) {
        q = head;
        for (j = 0; j < n - 1; j++) {
            q = q->next;
        }
        t = p->num;
        p->num = q->num;
        q->num = t;
        p = p->next;
        n--;
    }
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

WhenXuan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值