小小小小菜鸡 2018-06-10 06:26 采纳率: 100%
浏览 795
已采纳

问题简单,概念疑惑,求大神

图片说明
我想要这个题的完整解答。我自学c++和数据结构,无法理解链表,每次使用链表时都要自己创建,自己写函数输入输出?没有现成的函数?工具书上的源代码只是一个例子?

  • 写回答

5条回答 默认 最新

  • dabocaiqq 2018-06-10 06:36
    关注
     #include "stdio.h"
    
    struct ListNode {
        int val;
        struct ListNode *next;
    };
    
    ListNode* ReverseList(ListNode* pHead) {
            ListNode* newh = NULL;
            ListNode* p = pHead;
            while(p)
            {
                ListNode* tmp = p -> next;
                p -> next = newh;
                newh = p;
                p = tmp;
            }
            return newh;
        }
    
    void PrintList(ListNode* pHead) {
            while (pHead)
            {
                printf("%d ", pHead->val);
                pHead = pHead->next;
            }
            printf("\n");
        }
    
    int _tmain(int argc, _TCHAR* argv[])
    {
        ListNode p5; p5.val = 5; p5.next = NULL;
        ListNode p4; p4.val = 4; p4.next = &p5;
        ListNode p3; p3.val = 3; p3.next = &p4;
        ListNode p2; p2.val = 2; p2.next = &p3;
        ListNode p1; p1.val = 1; p1.next = &p2;
        PrintList(&p1);
        ListNode* newlist = ReverseList(&p1);
        PrintList(newlist);
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集