用C语言创建一个链表数据结构

链表是一种数据结构,对于要学习数据结构的人学习好链表是非常重要的。
一个链表需要包含什么呢,我的理解就是:1、有n个节点离散分配,2、每个节点通过指针来连接,3、每个节点都有一个前驱节点和一个后驱节点,4、首节点没有前驱节点,尾节点没有后驱节点。

一、节点的构造

typedef struct Nod
{
  int data;//存放数据的域
  struct Node *pNext;  //定义一个结构体指针,指向下一个数据类型相同的节点    
}NODE,*PNODE; //NODE等价于 struct Node; PNODE等价于struct Node *; 此处用大写是为了与变量区分,可以让人容易变出是个数据类型 

typedef 只是给数据类型取个别名,即 typedef 数据类型 别名;我们知道struct Node 是我们定义的数据类型;
(2)链表的创建
在创建链表之前,我们需要需要了解一下专业术语:
首节点:存放第一个有效数据的节点;
尾节点:存放最后一个有效数据的节点;
头节点:头节点的数据类型与首节点的数据类型相同,并且头节点是首节点前面的那个节点,并不存放有效数据;头节点的存在只是为了方便链表的操作。
头指针:指向头节点的指针;
尾指针:指向尾节点的指针;

二、在头节点后面插入一个节点

PNODE Create_Lise(void){
    int len;//存放链表的长度
    int i;//循环变量
    int val;//用来临时存放变量
    PNODE Lise;
    PNODE pHead=(PNODE) malloc(sizeof(NODE));//分配一个节点
    if(pHead==NULL){
        printf("请输入链表的值");
        exit(-1); 
    }else{
        PNODE pTail=pHead;
        pHead->pNext=null;
        printf("需要一个指针指向结尾");
        scanf("%d",&len);
        for(i=o;i<len;i++){
            PNODE p=(PNODE)malloc(sizeof(NODE));
            if(null=p){
                printf("插入了");
                exit(-1); 
            } else{
                printf("我在最后插入");
                scanf("%d",&val);
                p->data=val;
                pTail->pNext=p;
                p->pNext=null;
                pTail=p; 
            }
        } 
    }
}

三、向链表插入元素

//链表的第pos有效元素前面插入元素val,首先我们应该找到第pos个元素前面一个元素的位置;  
//当链表有3个元素时,pos=4,将不会进行插入操作  
 bool Insert_List(PNODE pHead,int pos,int val){
    int i=0;
    PNODE p=pHead;
    while((Null!=p)&&(i<pos-1)){
        p=p->pNext;
        i++
     }
     if(p==null||i>pos-1)//把链表为空的情况考虑进去了;i>pos-1可以防止用户输入错误;
     return false;
     
     //程序执行到这之后,i=pos-1;p指针指向链表第pos个有效节点前驱,即指向第pos-1节点;
     PNODE q=(PNODE)malloc(sizeof(NODE));
     q->data=val;
     q->pNext=p->pNext;
     p->pNext=q; 
 } 

四、删除链表中的元素

 bool Delete_Lise(PNODE pHead,int pos,int *var){
    int i=0;
    PNODE p=pHead;
    while((NULL!=p)&&(i<pos-1)){
        p=p->pNext;
        i++; 
    } 
    if(p==null||i>pos-1) //把链表表为空的情况去了
    return false;
    
     //程序执行到这后,i=pos-1;
     PNODE q=p->pNext;//q指向待删除的节点
     *val=q->data;
     p->pNext=q->pNext;//修改链表的指向
     free(q);          //释放q所指向节点的内存 
     q=NULL;  //如果不清空,会出现野指针 
 }

五来来来冒泡排序一下

void Sort_List(PNODE pHead){
    int i,j;
    int temp;
    int len=length_List(pHead);
    PNODE p,q;
    for(i=0,p-pHeda->pNext;i<len-1;i++,p->pNext){
        for(j=i+1,q=p->pNext;i<len;j++,q=q->pNext){
            
            //交换数据
              if(p->data>q->data){
                temp=p->data;
                p->data=q->data;
                q->data=temp;
              } 
          }
      } 
  } 
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • 本文内容:1、 什么是链表?2、 链表共分几类?3、 链表的 C 实现! 总表:《数据结构?》 工程代码 Gith...
    半纸渊阅读 39,915评论 0 54
  • 作为一个资深的新手程序员😂,链表这些既基础又深奥的东西是日常工作中并不常见,但是却非常重要,所以就总结一下链表的简...
    Clark_new阅读 4,234评论 4 12
  • VisuAlgo!一,Date Structure的核心技术是分解和抽象二,基本概念和常用术语 三,逻辑结构1,逻...
    斜杠青年许晏铭阅读 865评论 0 0
  • 一、数据结构绪论 逻辑结构与物理结构逻辑结构:集合、线性(一对一)、树(一对多)、图(多对多)物理结构:顺序存储结...
    scarqin阅读 2,519评论 0 3
  • 国庆这几天接新娘凌晨妆,弄得整个状态都特别累,10月5日结婚的新人特别多,据说是好日子,感觉在那一天结了就能天长地...
    Vicky靈氣阅读 243评论 0 1