struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2) { if(l1==NULL) return l2; if(l2==NULL) return l1; struct ListNode* result=(struct ListNode*)malloc(sizeof(struct ListNode)); int tmp=l1->val+l2->val; if(tmp<10){ result->val = tmp; result->next = addTwo...
✓ 已被采纳 本地变量在离开语句块后会弹出栈,ListNode l1(i)每次都会释放掉,而你这么做其实十分危险,之所以没有奔溃,是因为你逻辑简单。上一次释放掉的内存空间又被下一次的ListNode l1(i)填回来了,最终就是9的next指向自己。 new和malloc并不是在栈上分配内存的,所以不会自动被释放。 有用 回复 图样司...
/** * struct ListNode { * int val; * struct ListNode *next; * ListNode(int x) : val(x), next(nullptr) {} * }; */ #include <list> class Solution { public: /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param l1 ListNode类 * @param ...
这是你的问题的另一种解决方案。试试这个然后告诉我