鱼C论坛

 找回密码
 立即注册
查看: 2920|回复: 0

[学习笔记] 一个单链表L=(a1 , a2 , an-1 , an),其逆单链表定义为L’=( an , an-1 ...

[复制链接]
发表于 2021-5-18 18:10:34 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
/*

开发者:慢蜗牛 开发时间: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);//输出逆序链表
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-9 01:10

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表