c语言写两个链表相加

在 C 语言中,可以使用链表来存储一组数据。要想实现两个链表相加的功能,需要创建两个链表,然后遍历每一个节点,将它们的值相加,并将结果存储在新的链表中。

例如,假设有两个链表,分别为 A 和 B,其中 A 的值为 2->4->3,B 的值为 5->6->4,那么我们可以创建新的链表 C,并使用以下代码来遍历 A 和 B 的每个节点,将它们的值相加并存储在 C 中:

structNode {
  int val;
  struct Node* next;
};

struct Node* addTwoLists(struct Node* l1, struct Node* l2) {
  struct Node* result = NULL;
  struct Node* current = NULL;
  int carry = 0;
  while (l1 != NULL || l2 != NULL) {
    int sum = carry;
    if (l1 != NULL) {
      sum += l1->val;
      l1 = l1->next;
    }
    if (l2 != NULL) {
      sum += l2->val;
      l2 = l2->next;
    }
    carry = sum / 10;
    sum = sum % 10;

    if (result == NULL) {
      result = (struct Node*) malloc(sizeof(struct Node));
      result->val = sum;
      result->next = NULL;
      current = result;
    } else {
      current->next = (struct Node*) malloc(sizeof(struct Node));
      current = current->next;
      current->val = sum;
      current->next = NULL;
    }
  }
  if (carry > 0) {
    current->next = (struct Node*) malloc(sizeof(struct Node));
    current = current->next;
    current->val = carry;
    current->next = NULL;
  }
  return result;
}

在这段代码中,我们首先声明了一个名为 Node 的结构体,用于表示链表的节点。每个节点都

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值