欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言之單鏈表的插入、刪除與查找

 更新時(shí)間:2015年07月22日 10:20:14   作者:sky-zz  
本篇文章主要介紹了從單鏈表的創(chuàng)建、遍歷到節(jié)點(diǎn)的插入、刪除與查找功能的實(shí)現(xiàn),有需要的朋友可以參考下

單鏈表是一種鏈?zhǔn)酱嫒〉臄?shù)據(jù)結(jié)構(gòu),用一組地址任意的存儲單元存放線性表中的數(shù)據(jù)元素。要實(shí)現(xiàn)對單鏈表中節(jié)點(diǎn)的插入、刪除與查找的功能,就要先進(jìn)行的單鏈表的初始化、創(chuàng)建和遍歷,進(jìn)而實(shí)現(xiàn)各功能,以下是對單鏈表節(jié)點(diǎn)的插入、刪除、查找功能的具體實(shí)現(xiàn):

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

typedef int ElemType;

/**
*鏈表通用類型
*ElemType 代表自定義的數(shù)據(jù)類型 
*struct Node *next 代表 結(jié)構(gòu)體指針(指向下一個(gè)結(jié)構(gòu)體,完成鏈表動作) 
*/ 
typedef struct Node{
 ElemType data;
 struct Node *next;
}Node; 

/*==========單鏈表的初始化================*/
/*
*頭結(jié)點(diǎn)指針數(shù)據(jù)域設(shè)置為空 
*/ 
void initList(Node **pNode){
 *pNode=NULL;
}
/*===========單鏈表的創(chuàng)建=================*/
/*
*功能實(shí)現(xiàn):通過用戶不斷輸入數(shù)據(jù),創(chuàng)建鏈表
*利用游標(biāo)倆個(gè)指針(p1,p2),將申請下的數(shù)據(jù)塊(存入用戶輸入數(shù)據(jù)),鏈接起來 
*/ 
Node *create(Node *pHead){
 Node *p1;
 Node *p2;
 p1=p2=(Node *)malloc(sizeof(Node));     //申請內(nèi)存空間 
 memset(p1,0,sizeof(Node));       //存入數(shù)據(jù)域清空 
 scanf("%d",&p1->data);
 p1->next=NULL;          
 while(p1->data>0){         //輸入負(fù)數(shù)結(jié)束   
  if(pHead==NULL)
   pHead=p1;
  else
   p2->next=p1;
  p2=p1;
  p1=(Node *)malloc(sizeof(Node));
  memset(p1,0,sizeof(Node));
  scanf("%d",&p1->data);
  p1->next=NULL;
 }
 return pHead;
}
/*=================鏈表的遍歷==================*/
/**
*從頭結(jié)點(diǎn)開始,不斷遍歷出數(shù)據(jù)域的內(nèi)容將表遍歷 
*/ 
void printList(Node *pHead){
 if(NULL==pHead)
  printf("鏈表為空\n");
 else{
  while(pHead!=NULL){
   printf("%d ",pHead->data);
   pHead=pHead->next;
  }
 } 
 printf("\n");
} 
/*===============插入節(jié)點(diǎn)==================*/
/**
*Node **pNode 傳入頭結(jié)點(diǎn)空間地址
*int i 傳入要插入的結(jié)點(diǎn)位置 
*/ 
void insert_data(Node **pNode,int i){
 Node *temp;
 Node *target;
 Node *p;
 int item;
 int j=1;
 printf("輸入要插入的節(jié)點(diǎn)值:");
 scanf("%d",&item);
 target=*pNode;             
 for(;j<i-1;target=target->next,++j);  //不斷移動target位置,到要插入結(jié)點(diǎn)位置, 
 temp=(Node *)malloc(sizeof(Node));   //申請內(nèi)存空間 
 temp->data=item;       //存入要存入的數(shù)據(jù)位置 
 p=target->next;        
 target->next=temp;
 temp->next=p; 
} 
/*===============刪除節(jié)點(diǎn)====================*/
/**
*刪除結(jié)點(diǎn)后,釋放內(nèi)存空間free(temp) 
*/ 
void delete_data(Node **pNode,int i){
 Node *target;
 Node *temp;
 int j=1;
 target=*pNode;
 for(;j<i-1;target=target->next,++j);
 temp=target->next;
 target->next=temp->next;
 free(temp);
}
/*===============查找結(jié)點(diǎn)====================*/
int search_data(Node *pNode,int elem){
 Node *target;
 int i=1;
 for(target=pNode;target->data!=elem && target->next!=NULL;++i,target=target->next);
 if(target->next==NULL)
  return 0;
 else 
  return i;
 
} 
int main(){
 int i;
 Node *pHead=NULL;
 initList(&pHead);
 pHead=create(pHead);
 printList(pHead);
 printf("輸入插入節(jié)點(diǎn)位置\n");
 scanf("%d",&i);
 insert_data(&pHead,i);
 printList(pHead);
 printf("輸入刪除節(jié)點(diǎn)位置\n");
 scanf("%d",&i);
 delete_data(&pHead,i);
 printList(pHead);
 printf("輸入查找節(jié)點(diǎn)\n");
 scanf("%d",&i);
 printf("節(jié)點(diǎn)所在位置:%d",search_data(pHead,i));
 return 0;
}

通過以上各功能的實(shí)現(xiàn),希望對大家單鏈表的學(xué)習(xí)有所幫助。

相關(guān)文章

  • C/C++實(shí)現(xiàn)枚舉網(wǎng)上鄰居信息的示例詳解

    C/C++實(shí)現(xiàn)枚舉網(wǎng)上鄰居信息的示例詳解

    在Windows系統(tǒng)中,通過網(wǎng)絡(luò)鄰居可以方便地查看本地網(wǎng)絡(luò)中的共享資源和計(jì)算機(jī),本文將介紹一個(gè)簡單的C++程序,使用Windows API枚舉網(wǎng)絡(luò)鄰居信息,并獲取對端名稱、本機(jī)名稱、主機(jī)名稱以及主機(jī)IP等信息,文中通過代碼示例給大家講解非詳細(xì),需要的朋友可以參考下
    2023-12-12
  • C語言關(guān)鍵字之a(chǎn)uto register詳解

    C語言關(guān)鍵字之a(chǎn)uto register詳解

    這篇文章主要為大家介紹了C語言關(guān)鍵字之a(chǎn)uto register,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • C++ stack與queue使用方法詳細(xì)講解

    C++ stack與queue使用方法詳細(xì)講解

    stack是一種容器適配器,專門用在具有后進(jìn)先出操作的上下文環(huán)境中,其刪除只能從容器的一端進(jìn)行 元素的插入與提取操作;隊(duì)列是一種容器適配器,專門用于在FIFO上下文(先進(jìn)先出)中操作,其中從容器一端插入元素,另一端提取元素
    2023-01-01
  • C++?線段樹原理與實(shí)現(xiàn)示例詳解

    C++?線段樹原理與實(shí)現(xiàn)示例詳解

    這篇文章主要為大家介紹了C++?線段樹原理與實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Visual Studio 2019 如何新建 Win32項(xiàng)目的方法步驟

    Visual Studio 2019 如何新建 Win32項(xiàng)目的方法步驟

    這篇文章主要介紹了Visual Studio 2019 如何新建 Win32項(xiàng)目的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • C語言用easyx實(shí)現(xiàn)消磚塊游戲

    C語言用easyx實(shí)現(xiàn)消磚塊游戲

    這篇文章主要為大家詳細(xì)介紹了C語言消磚塊游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C++類的特種函數(shù)生成機(jī)制詳解

    C++類的特種函數(shù)生成機(jī)制詳解

    這篇文章主要給大家介紹了關(guān)于C++類特種函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-09-09
  • 數(shù)據(jù)結(jié)構(gòu)之AVL樹詳解

    數(shù)據(jù)結(jié)構(gòu)之AVL樹詳解

    這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)之AVL樹詳解,本文非常細(xì)致的講解了AVL樹的基礎(chǔ)知識、AVL樹的旋轉(zhuǎn)操作、AVL數(shù)的插入和刪除操作等,需要的朋友可以參考下
    2014-08-08
  • C語言實(shí)現(xiàn)小型電子詞典

    C語言實(shí)現(xiàn)小型電子詞典

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)小型電子詞典,用戶可以進(jìn)行英譯漢、漢譯英等功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • C語言實(shí)現(xiàn)簡易通訊錄實(shí)例

    C語言實(shí)現(xiàn)簡易通訊錄實(shí)例

    大家好,本篇文章主要講的是C語言實(shí)現(xiàn)簡易通訊錄實(shí)例,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02

最新評論