rust - ListNode 的下一个字段类型为 Option>,对吗?
问题描述
我试图解决https://leetcode.com/problems/add-two-numbers,这个问题很容易,但由于借用问题我无法完成它。我尝试了几个 3 小时,但我怀疑ListNode
的next
字段类型Option<Box<ListNode>>
不正确。
当我切换到 c# 时,我很快就解决了这个问题。以下是c#版本的解决方案。我无法将其翻译为生锈。
public class Solution {
public ListNode AddTwoNumbers(ListNode l1, ListNode l2) {
ListNode re = null;
ListNode next = null;
int carry = 0;
while(l1 != null || l2 != null) {
var val = (l1 != null ? l1.val : 0) + (l2 != null ? l2.val : 0) + carry;
carry = val / 10;
val %= 10;
if (re != null){
next.next = new ListNode(val);
next = next.next;
} else {
re = new ListNode(val);
next = re;
}
if (l1 != null) {
l1 = l1.next;
}
if (l2 != null) {
l2 = l2.next;
}
}
if (carry > 0) {
next.next = new ListNode(carry);
}
return re;
}
}
解决方案
根据@rodrigo 的建议。我终于以递归函数的方式解决了这个问题。
fn internal_add_two_number(
mut l1: &Option<Box<ListNode>>,
mut l2: &Option<Box<ListNode>>,
mut carry: i32,
) -> Option<Box<ListNode>> {
let mut sum = carry;
if l1.is_none() && l2.is_none() {
if carry > 0 {
return Some(Box::new(ListNode::new(carry)));
}
return None;
}
if let Some(p) = l1 {
sum += p.val;
l1 = &p.next;
}
if let Some(p) = l2 {
sum += p.val;
l2 = &p.next;
}
carry = sum / 10;
sum = sum % 10;
Some(Box::new(ListNode {
val: sum,
next: internal_add_two_number(l1, l2, carry),
}))
}
impl Solution {
pub fn add_two_numbers(
l1: Option<Box<ListNode>>,
l2: Option<Box<ListNode>>,
) -> Option<Box<ListNode>> {
internal_add_two_number(&l1, &l2, 0)
}
}
推荐阅读
- python - OpenCV's Warp Affine Has Lower Quality Compared to Photoshop
- azure - Azure Functions ServiceBus 触发器缩放行为
- c# - 将网格 N*N 存储到邻接图中?位置和邻居
- c# - 忽略空值补丁 ef core
- maven - 更改 Jenkins 共享库的 maven 存储库
- javascript - 将 react-pdf 渲染文件保存到状态以将其发送到服务器?
- java - 使用带有jsoup的java从html标签中提取值
- python - 关于 np.einsum
- heroku - 我一直在尝试升级我的 heroku postgres 数据库,但我不断收到类型错误
- scala - 如何简洁地在foreach中编写Future方法