如何将两个升序链表合并为一个降序链表?
算法的时间复杂度要求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无用
悬赏问题
- ¥50 用易语言http 访问不了网页
- ¥50 safari浏览器fetch提交数据后数据丢失问题
- ¥15 matlab不知道怎么改,求解答!!
- ¥15 永磁直线电机的电流环pi调不出来
- ¥15 用stata实现聚类的代码
- ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
- ¥20 docker里部署springboot项目,访问不到扬声器
- ¥15 netty整合springboot之后自动重连失效
- ¥15 悬赏!微信开发者工具报错,求帮改
- ¥20 wireshark抓不到vlan