my刷题记录

牛客-反串链表:

解题思想:申请新空间保存链表头数据,释放原链表头空间,递归执行

/**
 * struct ListNode {
 *  int val;
 *  struct ListNode *next;
 * };
 */
/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param head ListNode类
 * @return ListNode类
 */
struct ListNode* Reverse(struct ListNode* p, struct ListNode* rlist) {
    if (p != NULL) {
        struct ListNode* a;
        struct ListNode* tmp = p;
        // print(tmp);
        a = (struct ListNode*)malloc(sizeof(p));
        a->next = rlist;
        a->val = p->val;
        p = p->next;
        tmp->next = NULL;
        free(tmp);
        rlist = a;
        a = NULL;
        newList=rlist;//问题1改动处
        newList = Reverse(p, rlist);//问题2改动处
    }
    return newList;//问题1改动处
}
struct ListNode* ReverseList(struct ListNode* head ) {
    // write code here
    struct ListNode* p = head;
    if (p == NULL)
        return NULL;
    newList = Reverse(p, newList);
    return newList;
}

遇到问题:

1、最初Reverse函数仅当p==NULL时return

报错:non-void function does not return a value in all control paths

解决:return无条件执行

2、递归函数中仅在newList = Reverse(p, rlist);处为newList赋值,且return rlist。

错误:1、递归跳出时rlist更新,最终所得值是最初rlist值,不是期望执行到最后一层的rlist。

           2、newList在递归过程中没有发生改变

解决:每次递归函数中修改newList值,并最终返回newList,得到期待递归到最后一层的newList值。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值