单链表逆转


使用带头结点的方式进行创建,使用一个临时链表来实现对链表的逆转

链表的定义

typedef struct  List
{
    /* data */
    int data;
    struct  List * next;
}List , *LinkList;

带头结点链表的初始化

LinkList createList()
{
    LinkList linklist = (LinkList) malloc(sizeof(List));
    if(linklist == NULL)
    {
        printf("create fail\n");
    }
    linklist->next = NULL;
    return linklist;
}

带链表增加节点

void InsertList(LinkList linklist ,LinkList add_data)
{
    add_data->next = linklist->next; //头插法入队
    linklist->next = add_data;
	printf("insert data is %d \n ",linklist->next->data);
	
}

逆转函数

void reverse(LinkList linklist)
{
    LinkList p,tmp;
	tmp = (LinkList)malloc(sizeof(List));
    tmp->next = linklist->next;
    linklist->next = NULL;//置空
    while(tmp->next != NULL)
    {
		p = (LinkList)malloc(sizeof(List));
        p->data = tmp->next->data;
        p->next = linklist->next;//头插法入队
        linklist->next = p;
        tmp= tmp->next;
    }
}

打印链表

void printList(LinkList linklist)
{
	while(linklist->next != NULL)
	{
		printf("%d  ",linklist->next->data);
		linklist=linklist->next;
	}
}

完整的程序

/*
 * @描述: 
 * @版本: 
 * @作者: 
 * @Date: 2022-03-08 08:37:33
 * @LastEditors: Please set LastEditors
 * @LastEditTime: 2022-03-08 13:46:13
 */
#include<stdio.h>
#include<stdlib.h>
typedef struct  List
{
    /* data */
    int data;
    struct  List * next;
}List , *LinkList;
LinkList createList()
{
    LinkList linklist = (LinkList) malloc(sizeof(List));
    if(linklist == NULL)
    {
        printf("create fail\n");
    }
    linklist->next = NULL;
    return linklist;
}
void printList(LinkList linklist)
{
	while(linklist->next != NULL)
	{
		printf("%d  ",linklist->next->data);
		linklist=linklist->next;
	}
}
void InsertList(LinkList linklist ,LinkList add_data)
{
    add_data->next = linklist->next; //头插法入队
    linklist->next = add_data;
	printf("insert data is %d \n ",linklist->next->data);
	
}

void reverse(LinkList linklist)
{
    LinkList p,tmp;
	tmp = (LinkList)malloc(sizeof(List));
    tmp->next = linklist->next;
    linklist->next = NULL;//置空
    while(tmp->next != NULL)
    {
		p = (LinkList)malloc(sizeof(List));
        p->data = tmp->next->data;
        p->next = linklist->next;//头插法入队
        linklist->next = p;
        tmp= tmp->next;
    }
}

int main()
{
    int i ;
	
    LinkList list = createList();
    for( i = 0; i < 10 ; i++)
    {
		LinkList p = (LinkList)malloc(sizeof(List));
        p->data = i ;
        p->next = NULL;
        InsertList(list,p);
    }
	printf("list is: \n");
	printList(list);
    reverse(list);
	printf("\nreverse list is :\n");
	printList(list);
	return 0;
}

运行结果:
运行结果

#include <stdio.h> #include <stdlib.h> #define ERROR -1 #define OK 1 //定义单链表 typedef char ElemType; typedef struct LNode // 结点类型定义 { ElemType data; struct LNode * next; }LNode, *LinkList;//LinkList为结构指针类型 //定义关于单链表的若干操作 //初始化--建空表 void InitList(LinkList *L) { *L = (LinkList)malloc(sizeof(LNode)); (*L)->next=NULL; } //尾插法建表 void create_tail(LinkList *L, int n) { LNode *p, *last; int i; last=(*L); for(i=1; i<=n; i++) { p=(LNode *)malloc(sizeof(LNode)); //产生一个新结点 fflush(stdin); //清空内存 scanf("%c", &p->data); //往新结点的数据域中存入元素 last->next=p; //将新结点接在最后一个结点的后面 last=p; //新结点成为最后一个结点 } last->next=NULL; } //求单链表的长度 int ListLength(LinkList L) { LNode *p; int length; p=L->next; //p指针指向第一个元素所在的结点 length=0; //用来存放单链表的长度 while( p!=NULL ) //结点存在 { p=p->next; //p指针向后移 length++; //个数增加1个 } return length; } //求特定元素的个数 int Count(LinkList L, ElemType x) { LNode *p; int length; p=L->next; //p指针指向第一个元素所在的结点 length=0; //用来计算特定元素的个数 while( p ) //结点存在 { if( p->data ==x) //如果找到特定元素,则个数加1 length ++; p=p->next; //p指针向后移 } return length; } //在第i个元素前插入 int ListInsert_L(LinkList *L, int i, ElemType e) { LNode *p, *s; int j; p=(*L); j=0; while( p &&j<i-1) //如果当前结点存在,且移动次数未达到所需次数(找第i-1个结点) { p=p->next; j++; } if(!p || j>i-1) return ERROR; s=(LNode *)malloc(sizeof(LNode)); //产生一新结点 s->data=e; //往新结点中存入元素 s->next=p->next; p->next=s; //新结点接在p结点之后 return OK; } //删除第i个元素 int ListDelete_L(LinkList *L, int i, ElemType *e) { LNode *p,*q; int j; p=(*L); j=0; while(p->next && j<i-1)//(找第i-1个元素)如果当前结点的下一个结点存在,且移动次数未达到所需次数 { p=p->next; j++; } if(!p->next || j>i-1) return ERROR; q=p->next; p->next=q->next; *e=q->data; free(q); //释放要删除的结点 return OK; } void reverse(LinkList *L) { LNode *p,*q,*r; p=(*L)->next; q=p->next; r=q->next; p->next=NULL; while(q!=NULL) { q->next=p; (*L)->next=q; p=q; q=r; if(r!=NULL) r=q->next; else break; } } void main() { LinkList list1; InitList(&list1); create_tail(&list1, 5); LNode *p; for(p=list1->next; p; p=p->next ) printf("%c ",p->data ); printf("\n"); /* printf("\n========================================\n"); printf("\n单链表的长度:%d\n", ListLength(list1)); printf("\n========================================\n"); printf("单链表中元素c的个数:%d\n", Count(list1, 'c')); printf("\n========================================\n"); ListInsert_L(&list1, 3, 'g'); printf("在第3个元素前插入元素g后,单链表中的元素有:\n"); for(p=list1->next; p; p=p->next ) printf("%c ",p->data ); printf("\n"); printf("\n========================================\n"); ElemType e; ListDelete_L(&list1,4, &e); printf("删除第4个元素后,单链表中的元素有:\n"); for(p=list1->next; p; p=p->next ) printf("%c ",p->data ); printf("\n"); printf("删除掉的元素是:%c\n",e); */ reverse(&list1); for(p=list1->next; p; p=p->next ) printf("%c ",p->data ); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

曾许人间第一流.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值