C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)鏈表逆序并輸出
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)鏈表逆序并輸出
將一個(gè)鏈表逆序并輸出。我用了兩種方法來(lái)實(shí)現(xiàn),第一種是借助了一個(gè)新的空鏈表;第二種是在原來(lái)鏈表的基礎(chǔ)上直接實(shí)現(xiàn)逆序。
實(shí)例代碼:
頭文件:
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
typedef int ElemType;
typedef struct Node
{//結(jié)點(diǎn)結(jié)構(gòu)
ElemType value; //值域
struct Node *next;//指針域
}Node,*ptr_Node;
typedef struct LinkList
{//鏈表結(jié)構(gòu)
ptr_Node head; //鏈表頭結(jié)點(diǎn)指針
ptr_Node tail;//鏈表尾結(jié)點(diǎn)指針
int length; //鏈表長(zhǎng)度
}LinkList,*ptr_LinkList;
ptr_LinkList CreateList(void)
{//創(chuàng)建一個(gè)空鏈表
ptr_LinkList linklist;
linklist=(LinkList *)malloc(sizeof(LinkList));
if(!linklist)
{
printf("allocation failed.\n");
}
linklist->head=NULL;
linklist->tail=NULL;
linklist->length=0;
return linklist;
}
bool IsListEmpty(ptr_LinkList linklist)
{//判斷鏈表是否為空
if(linklist->length==0)
{
return true;
}
return false;
}
void InsertListHead(ptr_LinkList linklist,ElemType element)
{//在表頭插入值為element的結(jié)點(diǎn)作為新的表頭
ptr_Node ptr_node;
ptr_node=(Node *)malloc(sizeof(Node)); //生成插入結(jié)點(diǎn)
if(!ptr_node)
{
printf("allocation failed.\n");
}
else
{
ptr_node->value=element;
if(linklist->length==0)
{
linklist->head=ptr_node;
linklist->tail=linklist->head;
linklist->tail->next=NULL;
}
else
{
ptr_node->next=linklist->head;
linklist->head=ptr_node; //鏈表頭
}
linklist->length++; //鏈表長(zhǎng)度加1
}
}
void InsertListTail(ptr_LinkList linklist,ElemType element)
{
ptr_Node ptr_node;
ptr_node=(Node *)malloc(sizeof(Node)); //生成插入結(jié)點(diǎn)
if(!ptr_node)
{
printf("allocation failed.\n");
}
else
{
ptr_node->value=element;
if(linklist->length==0)
{
linklist->head=ptr_node;
linklist->tail=linklist->head;
linklist->tail->next=NULL;
}
else
{
linklist->tail->next=ptr_node;
linklist->tail=ptr_node; //鏈表尾
}
linklist->length++; //鏈表長(zhǎng)度加1
}
}
void InsertListPosition(ptr_LinkList linklist,int pos,ElemType element)
{
int i;
ptr_Node ptr_node;
ptr_Node temp_ptr_node;
if(pos<1 || pos>linklist->length)
{
printf("The insert position is invalidate.\n");
}
else
{
ptr_node=(Node *)malloc(sizeof(Node)); //生成插入結(jié)點(diǎn)
if(!ptr_node)
{
printf("allocation failed.\n");
}
ptr_node->value=element;
if(pos==1)
{
InsertListHead(linklist,element);
}
else if(pos==linklist->length)
{
InsertListTail(linklist,element);
}
else
{
temp_ptr_node=linklist->head;
for(i=1;i<pos-1;i++)
{//找到第pos-1個(gè)結(jié)點(diǎn)
temp_ptr_node=temp_ptr_node->next;
}
ptr_node->next=temp_ptr_node->next;
temp_ptr_node->next=ptr_node;
linklist->length++;
}
}
}
void Destroy(ptr_LinkList linklist)
{//銷毀鏈表
ptr_Node p=linklist->head;
ptr_Node q;
while(p)
{//釋放每個(gè)結(jié)點(diǎn)空間
q=p->next;
free(p);
p=NULL;
p=q;
}
}
void Traverse(ptr_LinkList linklist)
{//輸出整個(gè)鏈表
ptr_Node p;
p=linklist->head;
while(p)
{
printf("%4d",p->value);
p=p->next;
}
}
頭文件中實(shí)現(xiàn)了鏈表的幾個(gè)基本的操作,有的是必須的,有些是非必須的。
實(shí)現(xiàn)代碼:
#include "stdafx.h"
#include "LinkList.h"
#include <conio.h>
ptr_LinkList InvertList(ptr_LinkList list)
{//該方法借助一個(gè)新的空鏈表來(lái)實(shí)現(xiàn)鏈表逆序
ptr_LinkList inverted_linklist;
ptr_Node p;
p=list->head;
inverted_linklist=CreateList();//創(chuàng)建一個(gè)空鏈表
while(p)
{//將list鏈表中的結(jié)點(diǎn)值逆序輸入新創(chuàng)建的鏈表中,實(shí)現(xiàn)鏈表反轉(zhuǎn)
InsertListHead(inverted_linklist,p->value);
p=p->next;
}
return inverted_linklist;
}
void InvertLinkList(ptr_LinkList linklist)
{//該方法直接對(duì)原有鏈表實(shí)現(xiàn)逆序,不借助其他鏈表
ptr_Node p,q,r,m;
m=p=linklist->head;
q=p->next;
r=q->next;
while(r)
{//依次對(duì)鏈表中的結(jié)點(diǎn)進(jìn)行反轉(zhuǎn)
q->next=p;
p=q;
q=r;
r=r->next;
}
q->next=p; //最后一個(gè)結(jié)點(diǎn)反轉(zhuǎn)
linklist->head=q;
linklist->tail=m;
linklist->tail->next=NULL;
}
int _tmain(int argc, _TCHAR* argv[])
{
ptr_LinkList linklist;
ptr_LinkList list;
linklist=CreateList();
if(linklist)
{
printf("We have created a new linklist.\n");
}
InsertListHead(linklist,12);
InsertListHead(linklist,35);
InsertListHead(linklist,66);
InsertListHead(linklist,06);
InsertListHead(linklist,11);
InsertListHead(linklist,54);
InsertListHead(linklist,79);
Traverse(linklist);
printf("\n");
printf("The first method:\n");
list=InvertList(linklist);
Traverse(list);
printf("\n");
printf("The second method:\n");
InvertLinkList(linklist);
Traverse(linklist);
printf("\n");
getch();
return 0;
}
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
C語(yǔ)言基于循環(huán)鏈表解決約瑟夫環(huán)問(wèn)題的方法示例
這篇文章主要介紹了C語(yǔ)言基于循環(huán)鏈表解決約瑟夫環(huán)問(wèn)題的方法,簡(jiǎn)單描述了約瑟夫環(huán)問(wèn)題并結(jié)合實(shí)例形式分析了C語(yǔ)言使用循環(huán)鏈表解決約瑟夫環(huán)問(wèn)題的具體操作技巧,需要的朋友可以參考下2018-01-01
C++實(shí)現(xiàn)LeetCode(50.求x的n次方)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(50.求x的n次方),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
Qt中PaintEvent繪制實(shí)時(shí)波形圖的實(shí)現(xiàn)示例
本文主要介紹了Qt中PaintEvent繪制實(shí)時(shí)波形圖的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
C++ 中時(shí)間與時(shí)間戳的轉(zhuǎn)換實(shí)例詳解
這篇文章主要介紹了C++ 中時(shí)間與時(shí)間戳的轉(zhuǎn)換實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-06-06
C語(yǔ)言開(kāi)發(fā)中的常見(jiàn)錯(cuò)誤詳解
這個(gè)分欄是對(duì)于使用C語(yǔ)言編程過(guò)程中可能會(huì)出現(xiàn)的一些錯(cuò)誤而進(jìn)行的說(shuō)明,更多的錯(cuò)誤示例將會(huì)在后面的內(nèi)容里進(jìn)行演示。希望這個(gè)分欄的內(nèi)容可以幫助剛學(xué)編程的小白少走一些彎路,以及吸取更多的編碼經(jīng)驗(yàn)2022-05-05

