广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言如何实现链表逆序并输出
  • 855
分享到

C语言如何实现链表逆序并输出

2023-06-16 17:06:09 855人浏览 泡泡鱼
摘要

这篇文章主要介绍了C语言如何实现链表逆序并输出的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言如何实现链表逆序并输出文章都会有所收获,下面我们一起来看看吧。C语言数据结构实现链表逆序并输出将一个链表逆序并输

这篇文章主要介绍了C语言如何实现链表逆序并输出的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言如何实现链表逆序并输出文章都会有所收获,下面我们一起来看看吧。

C语言数据结构实现链表逆序并输出

将一个链表逆序并输出。我用了两种方法来实现,第一种是借助了一个新的空链表;第二种是在原来链表的基础上直接实现逆序。

实例代码:

    头文件:  

#include <stdio.h> #include <stdlib.h> #include <malloc.h> typedef int ElemType; typedef struct node {//结点结构  ElemType value;    //值域  struct Node *next;//指针域 }Node,*ptr_Node; typedef struct LinkList {//链表结构  ptr_Node head; //链表头结点指针  ptr_Node tail;//链表尾结点指针  int length;  //链表长度 }LinkList,*ptr_LinkList; ptr_LinkList CreateList(void) {//创建一个空链表  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的结点作为新的表头  ptr_Node ptr_node;  ptr_node=(Node *)malloc(sizeof(Node)); //生成插入结点  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++; //链表长度加1  } } void InsertListTail(ptr_LinkList linklist,ElemType element) {  ptr_Node ptr_node;  ptr_node=(Node *)malloc(sizeof(Node)); //生成插入结点  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++; //链表长度加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)); //生成插入结点   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个结点     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)  {//释放每个结点空间   q=p->next;   free(p);   p=NULL;   p=q;  } } void Traverse(ptr_LinkList linklist) {//输出整个链表  ptr_Node p;  p=linklist->head;  while(p)  {   printf("%4d",p->value);   p=p->next;  } }

    头文件中实现了链表的几个基本的操作,有的是必须的,有些是非必须的。

    实现代码:  

#include "stdafx.h" #include "LinkList.h" #include <coNIO.h> ptr_LinkList InvertList(ptr_LinkList list) {//该方法借助一个新的空链表来实现链表逆序  ptr_LinkList inverted_linklist;  ptr_Node p;  p=list->head;  inverted_linklist=CreateList();//创建一个空链表  while(p)  {//将list链表中的结点值逆序输入新创建的链表中,实现链表反转   InsertListHead(inverted_linklist,p->value);   p=p->next;  }  return inverted_linklist; } void InvertLinkList(ptr_LinkList linklist) {//该方法直接对原有链表实现逆序,不借助其他链表  ptr_Node p,q,r,m;  m=p=linklist->head;  q=p->next;  r=q->next;  while(r)  {//依次对链表中的结点进行反转   q->next=p;   p=q;   q=r;   r=r->next;  }  q->next=p; //最后一个结点反转  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; }

关于“C语言如何实现链表逆序并输出”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“C语言如何实现链表逆序并输出”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网其他教程频道。

--结束END--

本文标题: C语言如何实现链表逆序并输出

本文链接: https://www.lsjlt.com/news/284581.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言如何实现链表逆序并输出
    这篇文章主要介绍了C语言如何实现链表逆序并输出的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言如何实现链表逆序并输出文章都会有所收获,下面我们一起来看看吧。C语言数据结构实现链表逆序并输出将一个链表逆序并输...
    99+
    2023-06-16
  • C语言实现逆序输出详细
    问题:C语言实现对数组元素依次赋值0,1,2,3,4,5,6,7,8,9,然后按照逆序输出。 解题思路:显然首先要定义一个长度为10的数组,由于赋给的值是整数,因此,数组可以定义为整...
    99+
    2022-11-12
  • 使用C语言如何输出逆序数
    目录题目内容:第一种写法第二种写法C语言输入一个任意长度的整数,将其逆序输出总结题目内容: 从键盘任意输入一个3位整数,编程计算并输出它的逆序数(忽略整数前的正负号)。例如,输入-1...
    99+
    2022-11-12
  • c语言中递归字符串逆序输出怎么实现
    要实现递归字符串逆序输出,可以按照以下步骤进行:1. 定义一个递归函数,该函数接受一个字符串作为参数。2. 在递归函数中,首先判断字...
    99+
    2023-08-24
    c语言
  • c语言链表如何实现
    这篇“c语言链表如何实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“c语言链表如何实现”文章吧。在计算机领域离不开算法和数...
    99+
    2023-06-19
  • c语言如何反序输出
    要反序输出一个数组或者字符串,可以使用以下方法:1. 对于数组,可以使用循环从最后一个元素开始遍历,依次输出每个元素。例如:```c...
    99+
    2023-08-18
    c语言
  • c语言中如何实现逆序字符串
    这篇文章主要介绍了c语言中如何实现逆序字符串,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。使用指针逆序字符串思路:给两个指针,left放在字符串左侧,right放在最后一个有...
    99+
    2023-06-26
  • c语言如何实现声音输出
    在C语言中,可以使用音频库来进行声音输出。以下是使用ALSA音频库来实现声音输出的示例代码: #include int main...
    99+
    2023-10-25
    c语言
  • 如何使用C语言实现字符串逆序
    本篇内容介绍了“如何使用C语言实现字符串逆序”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!编写一个函数 r...
    99+
    2022-10-19
  • C语言如何实现双向链表
    本篇内容介绍了“C语言如何实现双向链表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!双向链表的基本操作    ...
    99+
    2023-06-16
  • C语言如何实现动态链表
    今天小编给大家分享一下C语言如何实现动态链表的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。链表是一种物理存储单元上非连续、非...
    99+
    2023-06-30
  • C语言中单链表如何实现
    这篇文章主要介绍“C语言中单链表如何实现”,在日常操作中,相信很多人在C语言中单链表如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C语言中单链表如何实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧...
    99+
    2023-07-04
  • c语言字符反序输出怎么实现
    实现C语言字符反序输出的方法有多种。以下是一种简单的实现方式: #include #include void reverseP...
    99+
    2023-10-25
    c语言
  • C语言如何输出教学日历表
    本篇内容主要讲解“C语言如何输出教学日历表”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言如何输出教学日历表”吧!按照格式分别输入学期,开学时间,总周数即可得到课程表,以回车结束。eg.学期...
    99+
    2023-06-30
  • C语言如何实现单链表操作
    本篇内容介绍了“C语言如何实现单链表操作”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1 链表的概念及结构概念:链表是一种物理存储结构上非连...
    99+
    2023-06-29
  • C语言顺序表如何实现
    这篇文章主要讲解了“C语言顺序表如何实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言顺序表如何实现”吧!概念及结构顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般...
    99+
    2023-06-29
  • c语言如何判断奇偶数并输出
    判断奇偶数的方法是通过对该数与2进行取余操作,如果结果为0,则为偶数;如果结果为1,则为奇数。下面是一个示例代码: #include...
    99+
    2023-10-23
    c语言
  • C语言指针如何实现字符串逆序反转
    目录指针实现字符串逆序反转知识点字符串逆序的几种写法非递归写法递归写法指针实现字符串逆序反转 #include<stdio.h> #include<string.h...
    99+
    2022-11-13
  • C语言如何实现一个链表队列
    本篇内容主要讲解“C语言如何实现一个链表队列”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言如何实现一个链表队列”吧!C语言数据结构链表队列的实现1.写在前面  队列是一种和栈相反的,遵循先...
    99+
    2023-06-16
  • c++如何实现归并两个有序链表
    目录归并两个有序链表1、题目描述2、设计思路将两个有序链表合并为一个新的有序链表并返回示例在力扣上的提交结果归并两个有序链表 1、题目描述 利用基础题里构建的单链表类创建两个有序的整...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作