C语言一个单链表L=(a1 , a2 , … , an-1 , an),其逆单链表定义为L’=( an , an-1 , … , a2 , a1),要求逆单链表仍占用原单链表的空间。

/*

开发者:慢蜗牛 开发时间:2020.6.11

程序功能:顺序输出和逆序输出

*/

#include<stdio.h>
#include<malloc.h>
#define LEN sizeof(struct L)

void print(struct L* head);
void _print(struct L* head);

struct L//结构体
{
    int a;

    struct L* next;
};

struct L* creat()//建立无头节点的链表
{
    struct L* head;

    struct L* p1, * p2; int n = 0;

    p1 = p2 = (struct L*)malloc(LEN);

    scanf_s("%d", &p1->a);

    head = NULL;

    while (p1->a != -1)
    {
        n = n + 1;

        if (n == 1) head = p1;

        else p2->next = p1;

        p2 = p1;

        p1 = (struct L*)malloc(LEN);

        scanf_s("%d", &p1->a);
    }
p2->next = NULL;

return(head);
}

void print(struct L* head)//顺序输出链表函数
{
    struct L* p;

    p = head;

    do
    {
        printf("--%d", p->a);

        p = p->next;
    } while (p != NULL);
}

void _print(struct L* head)//反转链表并输出
{
    struct L* p1, * p2, * p3, * p;

    p3 = p1 = p2 = (struct L*)malloc(LEN);

    p1->next = head; head = p1;

    p1 = head->next;

    do//反转
    {
        p3=head->next; p2 = p1->next;

        head->next = p2; p1->next = p2->next;

        p2->next = p3;
    } while (p1->next!=NULL);

    p = head->next;

    do//输出头节点链表
    {
        printf("--%d", p->a);

        p = p->next;
    } while (p != NULL);
}

void main()//主函数
{
    struct L* LA;

    LA = creat();//调用函数建立链表
    
    print(LA);//输出顺序链表

    printf("\n");

    print(LA);//输出逆序链表
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

放氮气的蜗牛

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

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

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

打赏作者

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

抵扣说明:

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

余额充值