亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C數(shù)據(jù)結(jié)構(gòu)之單鏈表詳細(xì)示例分析

 更新時間:2013年08月13日 09:28:04   作者:  
以下是對C語言中的單鏈表進行了詳細(xì)的分析介紹,需要的朋友可以過來參考下
復(fù)制代碼 代碼如下:

#include <stdio.h>
#include <stdlib.h>
typedef struct type
{
 int num;
 struct type *next;
}TYPE;
//=============================================================
// 語法格式: TYPE *init_link_head(int n)
// 實現(xiàn)功能: 從頭到尾,正序創(chuàng)建一個具有n個節(jié)點的鏈表,并對其值進行初始化
// 參數(shù):  n: 鏈表的長度,即節(jié)點的個數(shù)
// 返回值:  所創(chuàng)建鏈表的首地址
//=============================================================
TYPE *init_link_head(int n)
{
 int i;
 TYPE *phead = NULL, *pf = NULL, *pi = NULL;
 for(i=0; i<n; i++)
 {
  pi = (TYPE *)malloc(sizeof(TYPE));
  printf("please inout num:\n");
  scanf("%d",&pi->num);
  if(i == 0)
   pf = phead = pi;
  else
  {
   pf->next = pi;
   pf = pi;
  }
  pi->next = NULL;
 }
 return phead;
}
//=============================================================
// 語法格式: TYPE *init_link_end(int n )
// 實現(xiàn)功能: 從尾到頭,倒序創(chuàng)建一個具有n個節(jié)點的鏈表,并對其值進行初始化
// 參數(shù):  n: 鏈表的長度,即節(jié)點的個數(shù)
// 返回值:  所創(chuàng)建鏈表的首地址
//=============================================================
TYPE *init_link_end(int n )
{
 TYPE *phead = NULL, *pi = NULL;
 int i ;
 for(i=0; i<n; i++)
 {
  pi = (TYPE *)malloc(sizeof(TYPE));
  printf("please inout num:\n");
  scanf("%d",&pi->num);
  if(i == 0)
   pi->next = NULL;
  else
   pi->next = phead;
  phead = pi;
 }
 return phead;
}
//=============================================================
// 語法格式: insert_link(TYPE * phead,TYPE * pi)
// 實現(xiàn)功能: 將新申請的節(jié)點加入到指定鏈表中
// 參數(shù):  *phead:待插入鏈表
//    * pi:帶插入節(jié)點
// 返回值:  插入指定節(jié)點后的新鏈表首址
//=============================================================
TYPE * insert_link(TYPE *phead, TYPE *pi)
{
 TYPE *pb, *pf;
 pb = phead;
 if(phead == NULL)
 {
  phead = pi;
  phead->next = NULL;
 }
 else
 {
  while((pi->num > pb->num) && (pb->next != NULL))
  {
   pf = pb;
   pb = pb->next;
  }
  if(pi->num <= pb->num)
  {
   if(pb == phead)
   {
    pi->next = phead;
    phead = pi;
   }
   else
   {
    pf->next = pi;
    pi->next = pb;
   }
  }
  else
  {
   pi->next = NULL;
   pb->next = pi;
  }
 }
 return phead;
}
//=============================================================
// 語法格式: delete_link(TYPE * phead,int num)
// 實現(xiàn)功能: 刪除給定序號所指向的節(jié)點
// 參數(shù):  *phead:待刪除鏈表
//    num: 所需刪除的節(jié)點
// 返回值:  刪除指定節(jié)點后的新鏈表首址
//=============================================================
TYPE * delete_link(TYPE *phead, int num)
{
 TYPE *pf;
 TYPE *pb;
 if(phead == NULL)
 {
  printf("\nempty link\n");
  return NULL;
 }
 pb = phead;
 while((pb->num != num) && pb->next != NULL)
 {
  pf = pb;
  pb = pb->next ;
 }
 if(pb->num == num)
 {
  if(pb == phead)
   phead = phead->next;
  else
   pf->next = pb->next;
  free(pb);
  printf("the node is deleted\n");
 }
 else
  printf("the node not found\n");
 return phead;
}
//=============================================================
// 語法格式: print_link(TYPE * phead)
// 實現(xiàn)功能: 打印指定鏈表中的全部節(jié)點數(shù)據(jù)
// 參數(shù):  *phead:待打印的鏈表首址
// 返回值:  無
//=============================================================
void print_link(TYPE *phead)
{
 TYPE *temp = phead;
 while( temp != NULL)
 {
  printf(" %d ",temp->num);
  temp = temp->next;
 }
}
//=============================================================
// 語法格式: search_num(TYPE * phead,int num)
// 實現(xiàn)功能: 在指定的鏈表中,按姓名查找指定元素
// 參數(shù):  phead:待查找的鏈?zhǔn)字罚琻um需要查找的字符串
// 返回值:  無
//=============================================================
void search_num(TYPE *phead, int num)
{
 TYPE *temp = phead;
 while(temp != NULL)
 {
  if(temp->num == num)
   printf("  %d ",num);
  temp = temp->next;
 }
 if(temp == NULL)
  printf("node not been found\n");
}
//=============================================================
// 語法格式: order_link(TYPE * phead)
// 實現(xiàn)功能: 采用冒泡法,對指定鏈表按序號進行排序(交換數(shù)據(jù)域)
// 參數(shù):  phead:待排序的鏈?zhǔn)字?BR>// 返回值:  排好序的鏈表phead指針
//=============================================================
TYPE *order_link(TYPE *phead)
{
 TYPE *pb,*pf,temp;
 pb = pf =phead;
 if(phead == NULL)
  return NULL;
 while(pb->next != NULL)
 {
  pf = pb->next;
  while(pf != NULL)
  {
   if(pb->num > pf->num)
   {
    temp = *pb;
    *pb = *pf;
    *pf = temp;
    temp.next = pb->next;
    pb->next = pf->next;
    pf->next = temp.next;
   }
   pf = pf->next;
  }
  pb = pb->next;
 }
 return phead;
}
//=============================================================
// 語法格式: reverse_link(TYPE * phead)
// 實現(xiàn)功能: 對給定鏈表按序號進行倒序排序
// 參數(shù):  phead:待排序的鏈?zhǔn)字?BR>// 返回值:  排好序的鏈表phead指針
//=============================================================
TYPE *reverse_link(TYPE *phead)
{
 TYPE *pb, *pf, *temp;
 pb = phead;
 pf = pb->next;
 while(pf != NULL)
 {
  temp = pf->next;
  pf->next = pb;
  pb = pf;
  pf = temp;
 }
 phead->next = NULL;
 phead = pb;
 return phead;
}
//=============================================================
// 語法格式: free_all(TYPE * phead)
// 實現(xiàn)功能: 釋放鏈表中所有的節(jié)點
// 參數(shù):  phead:待釋放的鏈表首址
// 返回值:  無
//=============================================================
void free_all(TYPE *phead)
{
 TYPE *p;
 while(phead!=NULL)
 {
  p=phead->next;
  free(phead);
  phead=p;
 }
}
//=============================================================
// 語法格式: merge(TYPE *p1,TYPE *p2)
// 實現(xiàn)功能: 對兩個鏈表進行升序合并
// 參數(shù):  p1,p2兩個代合并的鏈表
// 返回值:  合并后的鏈表
//=============================================================
TYPE *merge_link(TYPE *p1, TYPE *p2)
{
 TYPE *p, *phead;
 if(p1 == NULL)
  return p2;
 if(p2 == NULL)
  return p1;
 if(p1->num < p2->num)
 {
  phead = p = p1;
  p1 = p1->next;
 }
 else
 {
  phead = p = p2;
  p2 = p2->next;
 }
 while(p1 != NULL && p2 != NULL)
 {
  if(p1->num < p2->num)
  {
   p->next = p1;
   p = p1;
   p1 = p1->next;
  }
  else
  {
   p->next = p2;
   p = p2;
   p2 = p2->next;
  }
 }
 if(p1 != NULL)
  p->next = p1;
 else
  p->next = p2;
 return phead;
}
//=============================================================
// 實現(xiàn)方法:   運用遞歸
// 語法格式: merge(TYPE *p1,TYPE *p2)
// 實現(xiàn)功能: 對兩個鏈表進行升序合并
// 參數(shù):  p1,p2兩個代合并的鏈表
// 返回值:  合并后的鏈表
//=============================================================
TYPE * merge_link_self(TYPE *p1, TYPE *p2)
{
 TYPE *phead = NULL;
 if(p1 == NULL)
  return p2;
 if (p2 == NULL)
  return p1;
 if(p1->num < p2->num)
 {
  phead = p1;
  phead->next =merge_link(p1->next, p2);
 }
 else
 {
  phead = p2;
  phead->next = merge_link(p1, p2->next);
 }
 return phead;
}
int main(void)
{
 return 0;
}

相關(guān)文章

  • C語言 擴展歐幾里得算法代碼

    C語言 擴展歐幾里得算法代碼

    這篇文章介紹了擴展歐幾里得算法的實現(xiàn)代碼,有需要的朋友可以參考一下
    2013-09-09
  • C++新特性詳細(xì)分析基于范圍的for循環(huán)

    C++新特性詳細(xì)分析基于范圍的for循環(huán)

    C++11這次的更新帶來了令很多C++程序員期待已久的for?range循環(huán),每次看到j(luò)avascript,?lua里的for?range,心想要是C++能有多好,心里別提多酸了。這次C++11不負(fù)眾望,再也不用羨慕別家人的for?range了。下面看下C++11的for循環(huán)的新用法
    2022-04-04
  • 關(guān)于C++中的static關(guān)鍵字的總結(jié)

    關(guān)于C++中的static關(guān)鍵字的總結(jié)

    C++的static有兩種用法:面向過程程序設(shè)計中的static和面向?qū)ο蟪绦蛟O(shè)計中的static。前者應(yīng)用于普通變量和函數(shù),不涉及類;后者主要說明static在類中的作用
    2013-09-09
  • C++中引用和const關(guān)鍵字介紹

    C++中引用和const關(guān)鍵字介紹

    大家好,本篇文章主要講的是C++中引用和const關(guān)鍵字介紹,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • C++ 中繼承與動態(tài)內(nèi)存分配的詳解

    C++ 中繼承與動態(tài)內(nèi)存分配的詳解

    這篇文章主要介紹了C++ 中繼承與動態(tài)內(nèi)存分配的詳解的相關(guān)資料,這里提供實例幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下
    2017-08-08
  • 使用Qt實現(xiàn)監(jiān)聽網(wǎng)頁是否響應(yīng)并導(dǎo)出Excel表

    使用Qt實現(xiàn)監(jiān)聽網(wǎng)頁是否響應(yīng)并導(dǎo)出Excel表

    Qt導(dǎo)出數(shù)據(jù)到excel,方法有很多,下面這篇文章主要給大家介紹了關(guān)于使用Qt實現(xiàn)監(jiān)聽網(wǎng)頁是否響應(yīng)并導(dǎo)出Excel表的相關(guān)資料,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • VSCode無法打開源文件及無法打開鏈接庫文件的解決方法

    VSCode無法打開源文件及無法打開鏈接庫文件的解決方法

    本文主要介紹了VSCode無法打開源文件及無法打開鏈接庫文件的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • c++ STL庫容器之集合set代碼實例

    c++ STL庫容器之集合set代碼實例

    在本篇文章里小編給大家整理的是關(guān)于c++STL庫容器之集合set代碼實例,需要的朋友們可以參考下。
    2020-03-03
  • C語言菜鳥基礎(chǔ)教程之自定義函數(shù)

    C語言菜鳥基礎(chǔ)教程之自定義函數(shù)

    自定義函數(shù): 必須直接或間接在main中調(diào)用,否則該自定義函數(shù)不會被執(zhí)行。 返回值類型 函數(shù)名(參數(shù)類型 參數(shù)名,參數(shù)類型 參數(shù)名...)
    2017-10-10
  • 一篇文章教你如何用C語言實現(xiàn)strcpy和strlen

    一篇文章教你如何用C語言實現(xiàn)strcpy和strlen

    這篇文章主要為大家介紹了C語言實現(xiàn)strcpy和strlen的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01

最新評論