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

随机链表的复制数据结构oj题(CM11)

目录

问题描述

题目解读

解决代码


问题描述

题目解读

这里给了一个头结点pHead,和一个定值x,这里要的是比x值小的结点要在x这个结点的左边,并且这里写着不改变数据顺序,也就是相对顺序。比如:{5,2,1,3,6},x=3;最终返回的顺序为{2,1,3,5,6}。

这里我们可以想到这里是用到单链表,很难从后往前去交换,所以我们这里就可以设置两个头结点,其中一个链表用来保存小于x的结点,还有一个保存大于等于x的结点,最后就能将两个链表合并在一起。

解决代码

/*
struct ListNode {int val;struct ListNode *next;ListNode(int x) : val(x), next(NULL) {}
};*/
class Partition {
public:ListNode* partition(ListNode* pHead, int x) {ListNode* lessHead,*lessTail;lessHead = lessTail =(ListNode*)malloc(sizeof(ListNode));if(lessHead == NULL){perror("malloc fali1");exit(1);}ListNode* greaterHead,*greaterTail;greaterHead = greaterTail = (ListNode*)malloc(sizeof(ListNode));if(greaterHead == NULL){perror("malloc fali2");exit(1);}//寻找ListNode* pcur = pHead;while(pcur){//小if(pcur->val < x){lessTail->next = pcur;lessTail = lessTail->next;}//大else {greaterTail->next = pcur;greaterTail = greaterTail->next;}pcur = pcur->next;}//合并lessTail->next=greaterHead->next;greaterTail->next = NULL;//防止过度访问ListNode* ret = lessHead->next;    //销毁  free(lessHead);free(greaterHead);return ret;}
};

http://www.dtcms.com/a/282278.html

相关文章:

  • SOTI MobiControl vs EasyControl:MDM 解决方案对比 —— 理解差异与价值
  • batchnorm1d,layernorm,revin区别
  • 关于程序=数据结构+算法这句话最近的一些思考
  • 【数据结构】「栈」(顺序栈、共享栈、链栈)
  • iOS 抓包工具选择与配置指南 从零基础到高效调试的完整流程
  • 时序大模型为时序数据库带来的变革与机遇
  • Flutter 记录 使用ModalRoute获取参数
  • flutter app内跳转到其他安卓 app的方法
  • qt udp接收时 丢包
  • 安卓开发使用Android Studio配置flutter环境
  • 《Qt信号与槽机制》详解:从基础到实践
  • Flutter运行Android项目时显示java版本不兼容(Unsupported class file major version 65)的处理
  • 《Qt实战开发》:从计算器到音乐播放器的全栈实现指南
  • 7月16日作业
  • QOpenGLWidget自定义控件— 2D点云显示(支持平移、放缩、绘制网格)
  • 桥下的蓝色风景线
  • 数据库连接池调优以及常见问题
  • SSM框架学习——day3
  • 如何解决WordPress数据库表损坏导致的错误
  • Python 测试全景:单元测试、集成测试与端到端测试实战指南
  • 【收银系统源码】-适用于零售餐饮连锁多门店
  • Docker化Web服务部署全景指南:从基础服务器到企业级应用
  • VUE指令大全
  • 使用Node搭建一个直播服务器,实时直播当前桌面
  • WAMP允许远程访问
  • WAN技术
  • 基于 Python/PHP/Node.js 的淘宝 API 商品数据抓取开发教程
  • 高德mcp结合智能体生成旅游计划推荐
  • Typecho插件开发:自定义表单验证规则addRule实战指南
  • 20250716|【继续19的快慢指针】Leetcodehot100之237【pass】今天计划