zoukankan      html  css  js  c++  java
  • 单链表尾插法,头结点作为结点个数进行计数

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>

    struct node
    {
        int data;
        struct node *pNext;
    };

    void insertTail(struct node *pH,struct node *new)
    {
        struct node *p=pH;
        int counter=0;
        
        while(NULL != p->pNext)
        {
            p=p->pNext;
            counter++;
        }
        
        p->pNext=new;
        pH->data=counter+1;
    }

    struct node *createNode(int data)
    {
        struct node *p = (struct node *)malloc(sizeof(struct node));
        if(NULL == p)
        {
            printf("malloc error ! ");
            return NULL;
        }
        
        memset(p,'',sizeof(struct node));
        
        p->data=data;
        p->pNext=NULL;
        
        return p;
    }

    int main()
    {
        struct node *pHeader;
        struct node *p,*p1,*p2;

        pHeader=createNode(0);

        insertTail(pHeader,createNode(1));
        insertTail(pHeader,createNode(2));
        insertTail(pHeader,createNode(3));
        insertTail(pHeader,createNode(4));

        printf("counter %d ",pHeader->data);

        printf("data %d ",pHeader->pNext->pNext->data);
        printf("hello world ! ");
        return 0;
    }

  • 相关阅读:
    Swift之 ? 和 !
    objective-c工程使用swift
    NSMethodSignature和NSInvocation的用法
    NSTimer
    iOS 的 XMPPFramework
    计算string高度
    python学习:猜数字小游戏
    python 各种控制语句
    ③ 小程序的代码组成
    ③ 组件&props
  • 原文地址:https://www.cnblogs.com/zhangjianrong/p/11624181.html
Copyright © 2011-2022 走看看