链表

链表

链表是什么:
其实是多个结构体,里面存有数据和指针,其中上一个结构体的指针成员指向了下一个结构体,如此往复,就可以实现链表。
如果我们想在链表后面加入新的内容,只需要再创建(malloc)一个节点,并使之前尾部的节点中的指针指向他。
链表可以分为两种:有空头和无空头,有空头也就是第一个节点使不储存数据的,其他节点都接在他的后面,无空头的链表第一个节点存有数据。

##创建链表
LinkList createListForHeadInsert() {
LinkList Head= (LinkList)malloc(sizeof(LinkList));
Head->next = NULL;
LNode *s;
int x;

while(scanf("%d",&x) && x!= -1) {
    s = (LNode*)malloc(sizeof(LNode*));
    s->data = x;
    s->next = Head->next;
    Head->next = s;
}

return Head;

}

##输出链表
void printList(LinkList Head) {
LNode *p;
for (p = Head->next;p!=NULL;p = p->next) {
printf("%d\t",p->data);
}
printf("\n");
}

##链表的逆置

头插法:

LinkList createListForHeadInsert() {
LinkList Head= (LinkList)malloc(sizeof(LinkList));
Head->next = NULL;
LNode *s;
int x;

while(scanf("%d",&x) && x!= -1) {
    s = (LNode*)malloc(sizeof(LNode*));
    s->data = x;
    s->next = Head->next;
    Head->next = s;
}

return Head;

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值