欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4263|回復: 0
打印 上一主題 下一主題
收起左側

C語言鏈表學習

[復制鏈接]
跳轉到指定樓層
樓主
鏈表有有頭鏈表和無頭鏈表
無頭鏈表:所有的節點都包含了有效數據。
有頭鏈表:用一個固定的頭節點來指代整個鏈表,所有的對象掛在這個頭節點下面,而頭節點本身不包含有效數據。
今天學習在有頭鏈表下插入節點,插入節點的方式有從頭部插入和從尾部插入,從頭部插入思路就是將頭部的節點地址復制給插入數據的節點地址,然后將頭部節點地址指向插入數據的地址。

程序實現方法:
#include<stdio.h>
#include <stdlib.h>
  struct  st
{
        int a;
        struct st *next;
};
struct  st d={0};
void add1(struct st* asj );
void add1(struct st * asj )  
{
        asj->next=d.next;
        d.next=asj;        
}
void main()
{
struct  st* obj_1 = (struct  st*)malloc (sizeof(struct  st));
  struct  st* obj_2 = (struct  st*)malloc (sizeof(struct  st));
  obj_1->a=0;
  add1(obj_1);
  printf("d=%d\n",&(d));
  printf("d.a=%d\n",&(d.a));
  printf("d.next=%d\n",&(d.next));
  printf("next=%d\n",d.next);
  printf("obj_1.a=%d\n",&(obj_1->a));
  printf("obj_1.next=%d\n",&(obj_1->next));
  printf("next=%d\n",obj_1->next);
  obj_2->a=0;
  add1(obj_2 );
  printf("obj_2.a=%d\n",&(obj_2->a));
  printf("obj_2.next=%d\n",&(obj_2->next));
  printf("obj_2.next=%d\n",obj_2->next);
}
運行結果為:
C:\Users\sky\AppData\Local\YNote\data\qq521525C35984A5C31E082DDBFE88B641\919e5ac8cd3140c1aa746edd894df2f0\捕獲.png
       從結果可以發現obj_1為最后一個節點,而后面插入的數據地址放到了obj_1的前面,而obj_2的節點地址指向了obj_1,這就是從首地址插入的方法。
       從尾部插入的方法是首先遍歷下鏈表找到最后一個元素,讓最后元素的節點指向要插入的數據,要插入的數據節點為0;
程序:
#include<stdio.h>
#include <stdlib.h>

  struct  st
{
        int a;
        struct st *next;
};
struct  st d={0};

void add2(struct st * asb );

void add2(struct st * asb )
{
        struct st *p=&d;
        while(p->next)
          p=p->next;
        p->next=asb;
        asb->next=0;

}

void main()
{
  struct  st* obj_1 = (struct  st*)malloc (sizeof(struct  st));
  struct  st* obj_2 = (struct  st*)malloc (sizeof(struct  st));
  obj_1->a=0;
  add2(obj_1);
  printf("d=%d\n",&(d));
  printf("d.a=%d\n",&(d.a));
  printf("d.next=%d\n",&(d.next));
  printf("next=%d\n",d.next);
  printf("obj_1.a=%d\n",&(obj_1->a));
  printf("obj_1.next=%d\n",&(obj_1->next));
  printf("next=%d\n",obj_1->next);
  obj_2->a=0;
  add2(obj_2 );
  printf("obj_2.a=%d\n",&(obj_2->a));
  printf("obj_2.next=%d\n",&(obj_2->next));
  printf("obj_2.next=%d\n",obj_2->next);

}
結果為:   

可見每次插入的數據下個節點總是指向了最后,而他們的內存是連續的。

鏈表的學習.pdf (63.45 KB, 下載次數: 25)
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表