久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4269|回復(fù): 0
收起左側(cè)

C語言鏈表學(xué)習(xí)

[復(fù)制鏈接]
ID:183246 發(fā)表于 2017-4-5 15:39 | 顯示全部樓層 |閱讀模式
鏈表有有頭鏈表和無頭鏈表
無頭鏈表:所有的節(jié)點都包含了有效數(shù)據(jù)。
有頭鏈表:用一個固定的頭節(jié)點來指代整個鏈表,所有的對象掛在這個頭節(jié)點下面,而頭節(jié)點本身不包含有效數(shù)據(jù)。
今天學(xué)習(xí)在有頭鏈表下插入節(jié)點,插入節(jié)點的方式有從頭部插入和從尾部插入,從頭部插入思路就是將頭部的節(jié)點地址復(fù)制給插入數(shù)據(jù)的節(jié)點地址,然后將頭部節(jié)點地址指向插入數(shù)據(jù)的地址。
0.png
程序?qū)崿F(xiàn)方法:
#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);
}
運(yùn)行結(jié)果為:
C:\Users\sky\AppData\Local\YNote\data\qq521525C35984A5C31E082DDBFE88B641\919e5ac8cd3140c1aa746edd894df2f0\捕獲.png
       從結(jié)果可以發(fā)現(xiàn)obj_1為最后一個節(jié)點,而后面插入的數(shù)據(jù)地址放到了obj_1的前面,而obj_2的節(jié)點地址指向了obj_1,這就是從首地址插入的方法。
       從尾部插入的方法是首先遍歷下鏈表找到最后一個元素,讓最后元素的節(jié)點指向要插入的數(shù)據(jù),要插入的數(shù)據(jù)節(jié)點為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);

}
結(jié)果為:   
0.png
可見每次插入的數(shù)據(jù)下個節(jié)點總是指向了最后,而他們的內(nèi)存是連續(xù)的。

鏈表的學(xué)習(xí).pdf (63.45 KB, 下載次數(shù): 25)
回復(fù)

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国产高清在线观看 | 精品国产一区一区二区三亚瑟 | 亚洲高清在线观看 | 久久噜噜噜精品国产亚洲综合 | 国产精品一区二区视频 | 日韩aⅴ在线观看 | 久久精品久久久久久 | 国产美女自拍视频 | 自拍视频一区二区三区 | 精品欧美一区二区在线观看视频 | 在线观看欧美日韩视频 | 午夜久久久久久久久久一区二区 | 天天插天天操 | 在线一区视频 | 成人免费视频网站在线看 | 欧美精品一二三区 | 日韩一区不卡 | 嫩草视频在线 | 日韩国产一区二区三区 | 婷婷一级片 | 久久久www成人免费无遮挡大片 | 成人小视频在线观看 | 精品亚洲一区二区三区四区五区 | 91一区二区 | 国产九九精品视频 | 一区二区三区四区在线播放 | 日韩在线观看中文字幕 | 亚洲精品一区二区三区在线观看 | 国产在线一区二区 | 欧美激情精品久久久久久免费 | 美女黄色在线观看 | 中文字幕专区 | 国产aⅴ精品 | 国产欧美一区二区三区在线看 | 全免费a级毛片免费看视频免费下 | 国产精品久久久亚洲 | 日韩在线精品视频 | 99亚洲精品 | 午夜av免费 | 免费国产视频在线观看 | 一区二区三区在线播放 |