单链表感悟

关于我最近对单链表的学习而言,单链表较数组而言,可以存储不同数据类型的成员,而且对于增添,删除数据等相较于数组而言更加简单,只需要创建一个新节点,而后将其通过结构体指针的形式进行原来节点与原来节点之前的节点进行拼接,而数组却需要进行对待处理节点的前后进行一个个移动,才能达到最终效果。 但在访问数据时,数组可以直接通过下标来访问数组,如a[3] = {1,3,5}中要想得到3则只用通过a[1],来进行操作,带对于访问结构体成员而言,则需要对于结构体变量,往往需要通过"."来实现, 而对于结构体指针来说,则需要用到"->" 或者"(*)"来实现。

以上是我自己对于这两者区别的理解。

对目前的我而言:单链表中的头插法,尾插法来进行成员的接入(前者最终的结果与输入的刚好倒过来,后者的最终结果与输入一致),这两者结合可以写回文数问题(151倒过来还是151)。

例如:

#include <stdio.h>
#include <stdlib.h>
    
struct Node
{
        int value;
        struct Node *next;
};
    
void insertHead(struct Node **head, int value)  
{
        struct Node *cur;
        struct Node *temp;
    
        cur = (struct Node *)malloc(sizeof(struct Node));
        if (cur == NULL)
        {
                printf("内存分配失败!\n");
                exit(1);
        }
    
        cur->value = value;
    
        if (*head != NULL)
        {
                temp = *head;
                *head = cur;
                cur->next = temp;
        }
        else
        {
                *head = cur;
                cur->next = NULL;
        }
}
    
void insertTail(struct Node **head, int value)
{
        struct Node *cur;
        struct Node *temp;
    
        cur = (struct Node *)malloc(sizeof(struct Node));
        if (cur == NULL)
        {
                printf("内存分配失败!\n");
                exit(1);
        }
    
        cur->value = value;
    
        if (*head != NULL)
        {
                temp = *head;
                while (temp->next != NULL)
                {
                        temp = temp->next;
                }
    
                temp->next = cur;
                cur->next = NULL;
        }
        else
        {
                *head = cur;
                cur->next = NULL;
        }
}
    
void printNode(struct Node *head)
{
        struct Node *cur;
    
        cur = head;
        while (cur != NULL)
        {
                printf("%d ", cur->value);
                cur = cur->next;
        }
        putchar('\n');
}
    
int recurCheck(struct Node *head, struct Node *tail)
{
        while (head)
        {
                if (head->value != tail->value)
                {
                        return 0;
                }
                head = head->next;
                tail = tail->next;
        }
    
        return 1;
}
    
 int main(void)
{
        struct Node *head = NULL;
        struct Node *tail = NULL;
        int input;
    
        while (1)
        {
                printf("请输入一个整数(输入-1表示结束):");
                scanf("%d", &input);
                if (input == -1)
                {
                        break;
                }
                insertHead(&head, input);
                insertTail(&tail, input);
        }
    
        printf("录入的单链表是:");
        printNode(tail);
    
        if (recurCheck(head, tail))
        {
                printf("录入的单链表是回文链表!\n");
        }
        else
        {
                printf("录入的单链表不是回文链表!\n");
        }
    
        return 0;
}

对输入的一组数据应用头插法和尾插法进行分别排列从而判断是否是回文数(经过B站上知名up主小甲鱼的C语言课后题吊打后,最终只能看着答案修改我那残破的代码!!)

对于链表的增添(对于一个已经有成员的链表)和删除我还懂得不是很好,还要好好钻研啊!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值