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

LeetCode-Day9-C++

搜索二维矩阵II

编写一个高效的算法来搜索mxn矩阵matrix中的一个目标值target。该矩阵具有以下特性:

  • 每行的元素从左到右升序排列。
  • 每列的元素从上到下升序排列。题目链接

示例 1:

输入:matrix = [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,24],[18,21,23,26,30]], target = 5输出:true

示例 2:

输入:matrix = [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,24],[18,21,23,26,30]], target = 20输出:false
class Solution { public: bool searchMatrix(vector<vector<int>>& matrix, int target) { int startrow = 0, startcol = matrix[0].size() - 1; while(startrow < matrix.size() && startcol >= 0){ if(matrix[startrow][startcol] > target){ startcol--; } else if(matrix[startrow][startcol] < target){ startrow++; } else{ return true; } } return false; } };

反转链表

给你单链表的头节点head,请你反转链表,并返回反转后的链表。题目链接

示例 1:

输入:head = [1,2,3,4,5]输出:[5,4,3,2,1]

示例 2:

输入:head = [1,2]输出:[2,1]

示例 3:

输入:head = []输出:[]
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */ class Solution { public: ListNode* reverseList(ListNode* head) { ListNode* pre = NULL; ListNode* last = head; if(!head){ return head; } while(last != NULL){ ListNode* temp = last->next; last->next = pre; pre = last; last = temp; } return pre; } };

回文链表

给你一个单链表的头节点head,请你判断该链表是否为回文链表。如果是,返回true;否则,返回false。题目链接

示例 1:

输入:head = [1,2,2,1]输出:true

示例 2:

输入:head = [1,2]输出:false
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */ class Solution { public: bool isPalindrome(ListNode* head) { ListNode* slow = head; ListNode* fast = head->next; //先把链表一份为二 while(fast && fast->next){ slow = slow->next; fast = fast->next->next; } //反转后半段链表 ListNode* second = reverselist(slow->next); slow->next = NULL; //比较两部分链表 ListNode* first = head; while(second){ if(first->val != second->val){ return false; } first = first->next; second = second->next; } return true; } ListNode* reverselist(ListNode* head){ ListNode* pre = NULL; ListNode* last = head; if(!head){ return head; } while(last){ ListNode* temp = last->next; last->next = pre; pre = last; last = temp; } return pre; } };
http://www.jsqmd.com/news/550657/

相关文章:

  • Serial Port Plotter:嵌入式开发者的实时数据可视化终极指南 [特殊字符]
  • 软萌拆拆屋企业应用:服装厂用Nano-Banana生成产前样衣结构说明图
  • 华硕笔记本终极优化指南:如何用GHelper告别臃肿控制软件
  • 林俊旸刚从阿里离职后,在(X)上发文章了
  • OpenClaw 的模型训练中,学习率调度策略是什么?是否使用 warmup?
  • 别再让电机‘嗡嗡’响了!用STM32F103和A3988驱动步进电机,手把手教你实现静音微步控制
  • 基于MATLAB的Boost升压式变换器系统设计之旅
  • STM32实战(五)卡尔曼滤波在ADC噪声抑制中的参数优化与效果对比
  • 不只是安装:用DVWA靶场在Kali上复现SQL注入漏洞,手把手教你从环境到实战
  • OpenClaw技能开发:为nanobot镜像制作专属的自动化插件
  • Tiled与Unity无缝衔接:地图转换工具如何解决2D游戏开发痛点
  • 智能化黑苹果配置工具:OpCore-Simplify效率提升完全指南
  • ArcGIS Pro 3.0 实战:用缓冲区+ArcScan搞定OSM双线路网转单线(附完整数据)
  • 打破35岁魔咒!如何用一行代码开启你的“一人公司”商业模式?
  • GD32F407的IAP升级,为什么你的APP程序一跑就飞?(中断向量表重映射详解)
  • 2026年,Shopify不再是唯一选择?这家SaaS平台让独立站建站成本归零 - 速递信息
  • 3步搞定Linux启动盘:Rufus格式化ext文件系统全攻略
  • 从零搭建汽车焊点检测系统:Python+Halcon混合编程实战(含焊渣干扰抑制算法、多光源融合触发代码、ISO 10360-5合规报告生成器)
  • 软考 系统架构设计师历年真题集萃(231)
  • GD32F303的RS485实战:用两线制半双工搭建一个稳定的Modbus主机
  • 运维老鸟的避坑笔记:DELL服务器Foreign磁盘状态的3种成因与预防
  • 基于Multisim与74系列芯片的数字时钟仿真与校准系统设计
  • 无需代码!用SiameseAOE搭建智能评论分析工具,市场调研神器
  • 从传统ARK工具到现代系统安全平台:OpenArk架构演进与技术实现
  • 聚焦核心业务:研发辅助体系使用心得与实战案例
  • 手机号查询QQ技术解析与实战指南
  • 从FAST_LIO到Livox HAP:ROS驱动版本升级中的消息适配实战
  • 高效微信聊天记录备份:让用户告别数据丢失风险的WeChatMsg实战指南
  • 如何让旧款Mac重获新生:OpenCore Legacy Patcher完全指南
  • 颗粒燃烧机厂家破局指南:‘4S’方法论助力工业企业实现热能转型 - 速递信息