当前位置: 首页 > news >正文

安徽旅游集团网站建设腾讯网站建设分析

安徽旅游集团网站建设,腾讯网站建设分析,济南高新区网站建设公司,焊锡外发加工网第一个是测试用例代码&#xff0c;测试的是两个带头的逆序链表相加&#xff0c;并且有反转操作 但是题目要求的是不带头链表直接相加&#xff0c;不需要逆转&#xff0c;输出结果也是逆序的&#xff0c; 题解放在第二个代码中 #include<stdio.h> #include<stdlib.h…

第一个是测试用例代码,测试的是两个带头的逆序链表相加,并且有反转操作

但是题目要求的是不带头链表直接相加,不需要逆转,输出结果也是逆序的,

题解放在第二个代码中

#include<stdio.h>
#include<stdlib.h>
typedef struct ListNode {int val;struct ListNode* next;
}List;List* reverse(List* L) {List* p = L;List* q = NULL;while (p != NULL) {List* temp = p->next;p->next = q;q = p;p = temp;}List* head = (List*)(malloc)(sizeof(List));head->next = q;List* temp = head;while (temp->next->next != NULL) {temp = temp->next;}temp->next = NULL;return head;
}
struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2) {List*L1=reverse(l1);L1->val = 0;List*L2=reverse(l2);L2->val = 0;List* L3 = (List*)(malloc)(sizeof(List));L3->next = NULL;L3->val = 0;int flag = 0;while (L1 != NULL || L2 != NULL) {List* temp = (List*)(malloc)(sizeof(List));temp->next = NULL;temp->val = 0;if (L1) {temp->val += L1->val;L1 = L1->next;}if (L2) {temp->val += L2->val;L2 = L2->next;}if (flag == 1) {temp->val += 1;flag = 0;}//进位if (temp->val >= 10) {temp->val= temp->val % 10;flag = 1;}//大于10进位List* cur = L3;while (cur->next != NULL) {cur = cur->next;}cur->next = temp;if (L1 == NULL && L2 == NULL && flag == 1) {List* digital = (List*)(malloc)(sizeof(List));digital->val = 1;digital->next = NULL;temp->next = digital;}}L3->next->val = 0;return reverse(L3->next);
}
List* makeList() {List* L = (List*)(malloc)(sizeof(List));L->next = NULL;int num;while (1) {scanf("%d", &num);if (num == 0) {break;}List* temp = (List*)(malloc)(sizeof(List));temp->next = NULL;temp->val = num;List* p = L;while (p->next != NULL) {p = p->next;}p->next = temp;}return L;
}
void print_List(List* L) {L = L->next; // 跳过头节点while (L != NULL) {printf("%d ", L->val);L = L->next;}printf("\n");
}int main() {List* L1 = makeList();printf("打印L1\n");print_List(L1);List* L3=reverse(L1);List* L2= makeList();printf("打印L2\n");print_List(L2);List* L4 = reverse(L2);printf("打印L3\n");print_List(L3);printf("打印L4\n");print_List(L4);List* L5 = addTwoNumbers(L3, L4);printf("打印L5\n");print_List(L5);
}

struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2) {struct ListNode* L3 = (struct ListNode*)(malloc)(sizeof(struct ListNode));L3->next = NULL;L3->val=0;int flag = 0;while (l1 != NULL || l2 != NULL) {struct ListNode* temp = (struct ListNode*)(malloc)(sizeof(struct ListNode));temp->next = NULL;temp->val = 0;if (l1) {temp->val += l1->val;l1 = l1->next;}if (l2) {temp->val += l2->val;l2 = l2->next;}if (flag == 1) {temp->val += 1;flag = 0;}//进位if (temp->val >= 10) {temp->val= temp->val % 10;flag = 1;}//大于10进位struct ListNode* cur = L3;while (cur->next != NULL) {cur = cur->next;}cur->next = temp;if (l1 == NULL && l2 == NULL && flag == 1) {struct ListNode* digital = (struct ListNode*)(malloc)(sizeof(struct ListNode));digital->val = 1;digital->next = NULL;temp->next = digital;}}return (L3->next);
}

http://www.yayakq.cn/news/300582/

相关文章:

  • 大连网站怎么上海哪家公司提供专业的网站建设
  • 网站开发网页济南新闻头条最新事件
  • 青岛网站seo收费标准西宁网站建设建站
  • 江苏省建设工程施工安全网站建设项目查询官网
  • 怎么看网站点击量科技新闻最新消息10条
  • 黑龙江建设人力资源网站站长工具之家seo查询
  • 网站建设 计划书关键词排名方案
  • 响应式网站图片代码合作制作网站
  • 学校网站建设的流程建设农产品网站的背景
  • 东阳实惠营销型网站建设域名注册规则
  • 制作网站升上去qifeiye做的网站如何
  • 网站策划与建设阶段的推广方法资源网站哪个好
  • 怎样建自己的网站做网站和维护网站
  • 商业网站可以选择.org域名吗济南网络优化中心照片
  • 网站优化工作室百度竞价排名事件
  • 益阳购物网站开发设计百度快照优化培训班
  • 网站建设需要些什么资料海口网站制作公司
  • 网站建设赚钱流程维护平台是什么工作
  • 网站建设制作鸿运通帝国cms导航模板
  • 苏州建设网站找网络公司建设局焊工证图样
  • 手机能制作网站吗优化网站排名工具
  • 甘肃城乡建设厅网站首页保定制作公司网站的公司
  • 酒楼网站模板深圳市设计网站公司
  • 厦门网站建设招标为什么两学一做进不去网站
  • 重庆快速网站备案大淘客可以做几个网站
  • 腾讯 网站建设常州网站建设方案维护
  • 网站seo排名优化价格电子商务网站建设步骤百度文库
  • 做建筑设计的网站推荐网上培训
  • 关于做网站的搞笑段子网站付款接口这么做
  • 谷歌网站关键词优化wordpress 弹出窗口