单链表反转第m个结点到第n个结点/非递归C语言实现

第m个结点到第n个结点反转单链表

step1
在这里插入图片描述

step2
在这里插入图片描述
step3
在这里插入图片描述
代码实现

#include<stdio.h>
#include<malloc.h>
typedef struct node
{
    int data;
    struct node *next;
}*list;
list gen()
{
    list head,end,node;
    int num;
    head=(list)malloc(sizeof(struct node));
    end=head;
    scanf("%d",&num);
    while(num>=0)
    {
        node=(list)malloc(sizeof(struct node));
        node->data=num;
        end->next=node;
        end=node;

        scanf("%d",&num);
    }
     end->next=NULL;  
     return head; 
}
list reverse(int start,int end,list head)
{
    int i;
    int cnt;
    list temp,new,old,idx;
    temp=head;
    new=head;
    for(i=0;i<start;i++)//step1:找到temp,old,new的位置
    {
        if(i<start-1)
        {
            temp=temp->next;
        }
        new=new->next;      
    }
    old=new->next;
    idx=old->next;
    for(cnt=0;cnt<end-start;cnt++)
    {
        old->next=new;//step2依次反转
        new=old;//step3移位置
        old=idx;
        if(idx)
          idx=idx->next;
        
    }
    temp->next->next=old;//连接新头和新尾
    temp->next=new;
    
    return head;

}
void display(list head)
{
    int flag=0;
    while(head->next)
    {
        head=head->next;
        if(flag==0)
        {
            printf("%d",head->data);
            flag=1;
        }
        else
        {
            printf(" %d",head->data);
        }
        

    }
}
int main()
{
    list head;
    int start,end;
    head=gen();
    display(head);
    scanf("%d%d",&start,&end);
    head=reverse(start,end,head);
    display(head);
    return 0;
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现带头结点单链表反向输出每个结点的值,可以使用递归或者栈来实现。下面是一个使用递归的示例C语言代码: ```c #include <stdio.h> #include <stdlib.h> // 定义链表结点结构 typedef struct Node { int data; struct Node* next; } Node; // 创建一个带头结点的链表 Node* createLinkedList() { Node* head = (Node*)malloc(sizeof(Node)); head->next = NULL; return head; } // 向链表中插入新结点 void insertNode(Node* head, int value) { Node* newNode = (Node*)malloc(sizeof(Node)); newNode->data = value; newNode->next = head->next; head->next = newNode; } // 递归反向输出每个结点的值 void reversePrint(Node* node) { if (node == NULL) { return; } reversePrint(node->next); printf("%d ", node->data); } // 释放链表内存 void freeLinkedList(Node* head) { Node* curr = head; while (curr != NULL) { Node* temp = curr; curr = curr->next; free(temp); } } int main() { Node* head = createLinkedList(); // 插入测试数据 insertNode(head, 3); insertNode(head, 6); insertNode(head, 2); insertNode(head, 8); insertNode(head, 9); printf("反向输出每个结点的值:"); reversePrint(head->next); printf("\n"); freeLinkedList(head); return 0; } ``` 在这个示例中,我们首先创建了一个带头结点的链表,并向其中插入一些测试数据。然后,我们使用`reversePrint`函数递归地反向输出每个结点的值。最后,我们释放链表的内存。 希望这个示例能够帮助到你!如果你还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值