编写一个函数int list_revert(SLIST_S *listA, SLIST_S *listB),将传入的单向链表listA反转后返回listB

该程序使用C语言创建了一个链表结构,包括初始化链表、添加元素、显示链表元素以及实现链表逆序的功能。通过`initLink`初始化链表,`addelem`添加元素,`show`打印链表,`list_revert`完成链表逆序。在主函数中展示了这些操作的使用。
摘要由CSDN通过智能技术生成

用c语言实现此函数,如下 完成代码

#include <stdio.h>
#include <stdlib.h>
#define ElemDate int
typedef struct SLIST
{
    ElemDate data;
    struct SLIST *next;
} SLIST_S, *LINK;
//初始化链表
int initLink(LINK *link)
{
    *link = (LINK)malloc(sizeof(SLIST_S));
    if (*link == NULL)
        return -1;
    (*link)->next = NULL;
    return 0;
}
//添加元素
SLIST_S *addelem(SLIST_S *list)
{
    int ch,n, i = 0;

    SLIST_S *listnode = list;
    printf("input number:");
    scanf("%d",&n);//确定输入的元素的个数
    while (i < n)
    {
        SLIST_S *p = (LINK)malloc(sizeof(SLIST_S));
        printf("input:");
        scanf("%d", &ch);
        p->data = ch;
        listnode->next = p;
        listnode = p;
        i++;
    }
    return list;
}
//打印元素
int show(SLIST_S *list)
{

    SLIST_S *listnode = list->next;
    if (listnode == NULL)
    {
        printf("erro\n");
        return 0;
    }
    printf("ele:");
    while (listnode)
    {
        printf("%2d", listnode->data);
        listnode = listnode->next;
    }
    printf("\n");
}

//将链表A的结点给B链表,B链表通过头节点插入法从而实现A链表的结点逆序 
int list_revert(SLIST_S *listA, SLIST_S *listB)
{
    SLIST_S *pb = listB;
    SLIST_S *pa = listA->next;
    SLIST_S *q = NULL;
    while (pa)
    {
        q = pa;
        pa = pa->next;
        q->next = pb->next;
        pb->next = q;
    }
    return 0;
}
//主函数
int main(int argc, char const *argv[])
{
    SLIST_S *listA, *listB;
    initLink(&listA);
    initLink(&listB);
    addelem(listA);
    show(listA);
    list_revert(listA, listB);
    show(listB);
    return 0;
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值