Programming 板


LINE

各位高手大家好,今天练习这题时有些疑惑想请教 题目:https://leetcode.com/problems/remove-nth-node-from-end-of-list/descripti on/ 一开始写出的做法如下: ``` class Solution { public: ListNode* removeNthFromEnd(ListNode* head, int n) { static int i = 0; if (head->next != NULL) { head->next = removeNthFromEnd(head->next, n); } i++; if (n == i) { return head->next; // skip yourself } else { return head; } } }; ``` 在Leetcode上无法通过([1], 1)与([1,2], 1)这两个测试 回传结果是[1]与[1,2],也就是并没有成功移除node 我知道这段code并没有实际删除node,只是忽略掉 但走访起来应该跟正确答案相符,且在vs上测试可以得到正确答案 目前已知: 1. 不建议用static变数 2. 会有mem leak的问题 但神奇的事情发生了,我把static换成call by reference的做法,就通过leetcode的测 试了?!? ``` class Solution { public: ListNode* removeNthFromEnd2(ListNode* head, int& n) { if (head->next != NULL) { head->next = removeNthFromEnd2(head->next, n); } n--; if (n == 0) { return head->next; // skip yourself } else { return head; } } ListNode* removeNthFromEnd(ListNode* head, int n) { return removeNthFromEnd2(head, n); } }; ``` 我觉得这两段code执行起来逻辑相同, 是不是有什麽盲点? 另外有没有可能维持这个逻辑,但解决mem leak的问题呢? 恳请大大们解惑 ----- Sent from MeowPtt on my Pixel 6 --
QR Code



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 42.72.118.225 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Programming/M.1708680307.A.B79.html
1F:→ lycantrope: 要不要先用python3写对,再去想c++ 133.106.37.183 02/23 17:56
2F:推 LPH66: 你不能假设你的函数只被测试程式呼叫一次123.194.181.180 02/23 19:38
3F:→ LPH66: static 变数只会初始化一次, 再次呼叫时123.194.181.180 02/23 19:39
4F:→ LPH66: 不会再去清一次零; 第二种写法你用额外变数123.194.181.180 02/23 19:40
5F:→ LPH66: 没有使用 static 就不会有这问题123.194.181.180 02/23 19:41
6F:→ buyfood: 对耶,呼叫多次就错了,感谢指出 42.72.118.225 02/23 21:25







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:BabyMother站内搜寻

TOP