如何将两个升序链表合并为一个降序链表?
算法的时间复杂度要求O(n),空间复杂度要求O(1).
C语言实现。
如何将两个升序链表合并为一个降序链表?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 广大菜鸟 2022-03-11 17:09关注
#include<stdio.h> #include<stdlib.h> typedef struct Node{ int value; struct Node*next; }Node; Node*function(Node*t1,Node*t2){ Node*head=(Node*)malloc(sizeof(Node)); head->next=NULL; Node*p,*q; p=t1,q=t2; while(p!=NULL&q!=NULL){ Node*tmp=(Node*)malloc(sizeof(Node)); if(p->value<q->value){ tmp->value=p->value; p=p->next; }else{ tmp->value=q->value; q=q->next; } tmp->next=head->next; head->next=tmp; } while(p!=NULL){ Node*tmp=(Node*)malloc(sizeof(Node)); tmp->value=p->value; tmp->next=head->next; head->next=tmp; p=p->next; } while(q!=NULL){ Node*tmp=(Node*)malloc(sizeof(Node)); tmp->value=q->value; tmp->next=head->next; head->next=tmp; q=q->next; } return head->next; } int main(){ //1-3-5 Node*t=(Node*)malloc(sizeof(Node));t->value=1; t->next=(Node*)malloc(sizeof(Node));t->next->value=3; t->next->next=(Node*)malloc(sizeof(Node));t->next->next->value=5; t->next->next->next=NULL; //2-4-6 Node*t1=(Node*)malloc(sizeof(Node));t1->value=2; t1->next=(Node*)malloc(sizeof(Node));t1->next->value=4; t1->next->next=(Node*)malloc(sizeof(Node));t1->next->next->value=6; t1->next->next->next=NULL; Node*result=function(t,t1); Node*p=result; while(p!=NULL){ printf("%d\t",p->value); p=p->next; } system("pause"); }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 3无用
悬赏问题
- ¥20 c语言写的8051单片机存储器mt29的模块程序
- ¥60 求直线方程 使平面上n个点在直线同侧并且距离总和最小
- ¥50 java算法,给定试题的难度数量(简单,普通,困难),和试题类型数量(单选,多选,判断),以及题库中各种类型的题有多少道,求能否随机抽题。
- ¥50 rk3588板端推理
- ¥250 opencv怎么去掉 数字0中间的斜杠。
- ¥15 这种情况的伯德图和奈奎斯特曲线怎么分析?
- ¥250 paddleocr带斜线的0很容易识别成9
- ¥15 电子档案元素采集(tiff及PDF扫描图片)
- ¥15 flink-sql-connector-rabbitmq使用
- ¥15 zynq7015,PCIE读写延时偏大