真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

編程語言中如何創(chuàng)建和讀取雙向鏈表-創(chuàng)新互聯(lián)

這篇文章將為大家詳細講解有關(guān)編程語言中如何創(chuàng)建和讀取雙向鏈表,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

在簡陽等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都做網(wǎng)站、成都網(wǎng)站制作 網(wǎng)站設(shè)計制作定制設(shè)計,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),成都全網(wǎng)營銷,外貿(mào)網(wǎng)站建設(shè),簡陽網(wǎng)站建設(shè)費用合理。

雙向鏈表是為了滿足更加方便的查找前驅(qū),而付出空間的代價的一個數(shù)據(jù)結(jié)構(gòu)。雙向鏈表的節(jié)點定義如下:

 typedef struct node
 {
   int x;
   struct node *prior,*next;
 }DLNode;

雙向鏈表的空間結(jié)構(gòu)如下圖所示:

編程語言中如何創(chuàng)建和讀取雙向鏈表

雙向鏈表的創(chuàng)建如下:

//創(chuàng)建雙向鏈表
DLNode *create_DList()
{
  DLNode *p,*h,*l;
  int n,i,x;
  h = (DLNode *)malloc(sizeof(DLNode));
  h->prior = h;    //當(dāng)空的雙向鏈表就像上圖那樣前驅(qū)和后驅(qū)都會指向自己;
  h->next = h;
  p = h;
  printf("請輸入需要創(chuàng)建雙向鏈表的長度:");
  scanf("%d",&n);
  for(i = 0; i < n; i++)
  {
    printf("請輸入第%d個數(shù)",i+1);
    scanf("%d",&x);
    l = (DLNode *)malloc(sizeof(DLNode));
    l->x = x;
    p->next = l;
    l->prior = p;
    l->next = h;     //注意,l->next鏈接的是頭節(jié)點, 
    h->prior = l;    //而頭結(jié)點的前驅(qū)是l。 這樣便構(gòu)成了一個循環(huán)的雙向鏈表
    p = l;
  }
  return(h);  //不要忘記返回鏈表
}

上面綠顏色的字需要注意;

讀取雙向鏈表的代碼如下:

void out_DList(DLNode *l)
{
  DLNode *p;
  int i;
  p = l;
  p = p->next;
  while(p!=l)  //注意條件發(fā)生了變化
  {
    printf("%5d",p->x);
    p = p->next;  //不要忘記讓p指向下一個節(jié)點;
  }
}

注意:①:由于頭節(jié)點的值為空,所以p = p->next; ②:循環(huán)的條件發(fā)生了變化,因為這是一個循環(huán)鏈表,鏈表的尾部指向頭部,所以條件是p!=l;

全部代碼如下:

#include
#include 

typedef struct node
{
  int x;
  struct node *prior,*next;
}DLNode;

//函數(shù)聲明
DLNode *create_DList();
void out_DList(DLNode *l);

main()
{
  DLNode *l;
  l = create_DList();
  printf("創(chuàng)建成功!");
  out_DList(l);
}

//讀取雙向鏈表
void out_DList(DLNode *l)
{
  DLNode *p;
  int i;
  p = l;
  p = p->next;
  while(p!=l)
  {
    printf("%5d",p->x);
    p = p->next;
  }
}


//創(chuàng)建雙向鏈表
DLNode *create_DList()
{
  DLNode *p,*h,*l;
  int n,i,x;
  h = (DLNode *)malloc(sizeof(DLNode));
  h->prior = h;
  h->next = h;
  p = h;
  printf("請輸入需要創(chuàng)建雙向鏈表的長度:");
  scanf("%d",&n);
  for(i = 0; i < n; i++)
  {
    printf("請輸入第%d個數(shù)",i+1);
    scanf("%d",&x);
    l = (DLNode *)malloc(sizeof(DLNode));
    l->x = x;
    p->next = l;
    l->prior = p;
    l->next = h;
    h->prior = l;
    p = l;
  }
  return(h);
}

關(guān)于“編程語言中如何創(chuàng)建和讀取雙向鏈表”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


文章標題:編程語言中如何創(chuàng)建和讀取雙向鏈表-創(chuàng)新互聯(lián)
標題URL:http://weahome.cn/article/joids.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部