个人理解—链表3(单链表头插与单链表遍历)

        说明是头插法,就是在链表的头结点后插入一个新的结点,而不是在链表尾部添加新结点。

void inset_head(struct node *pH,struct node *new)
{
    new->pNext=pH->pNext;
    pH->pNext=new;
    pH->data+=1;
}

int main()
{
    struct node *pHeader=create_node(0);
    inset_head(pHeader,create_node(1));
    inset_head(pHeader,create_node(2));
    inset_head(pHeader,create_node(3));
}

      其中"->"的实际是对结构体的成员访问。如pH->data+=1。真正进行链表链接的是"="。如p->pNext=new。

        什么是遍历,遍历不可重复,不可遗漏,高效。从头结点开始,NULL结束。起始于“->”到结尾只有一条路。头指针+头节点为开始,一次得到数据,结束并返回。

方法1:
void traversal(struct node *pH)
{
    struct node *p=pH->pNext;  跳过头节点
    //pH->data为头节点数据不算遍历点
    
    while(NULL!=p->pNext)
        {
            printf("node data:%d\n",p->data); 只能打印到结点数-1,因为NULL结点指向NULL
            p=p->pNext;
        }    
    printf("node data:%d\n",p->data);  补充打印lost结点
}
方法2:
void traversal(struct node *pH)
{
    struct node *p=pH;  先不跳过头节点

    while(NULL!=p->pNext)
        { 
            p=p->pNext;        跳过头节点
            printf("node data:%d\n",p->data);
        }    
}

        

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值