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

Leetcode hot 100

双指针

283.移动零

class Solution {
public:void moveZeroes(vector<int>& nums) {int cnt = 0;for(vector<int>::iterator it = nums.begin(); it != nums.end(); ){if(*it == 0) it = nums.erase(it),cnt++;else it++;}while(cnt--){nums.push_back(0);}}
};

11.盛水最多的容器

class Solution {
public:int maxArea(vector<int>& height) {int l = 0, r = height.size()-1;int ans = 0;while(l < r){int t = min(height[l], height[r]) * (r-l) ;ans = max(ans, t);if(height[l] < height[r]) l++;else r--;}return ans;}
};

53. 最大子数组和

class Solution {
public:int maxSubArray(vector<int>& nums) {return  maxx(nums, 0, nums.size() - 1);}int maxx(vector<int>& nums, int l, int r) {if (l > r) return 0;if (l == r) {return nums[l];}int mid = (l + r) / 2;int ret = maxx(nums, l, mid);if(mid + 1 <= r)ret = max(ret, maxx(nums, mid + 1, r));int i = mid-1, j = mid+1;int tmp = nums[mid], maxone = tmp;while ( i >= l ) {tmp += nums[i];if (tmp >= maxone)maxone = max(maxone, tmp);i--;}tmp = maxone;while ( j <= r ) {tmp += nums[j];if ( tmp >= maxone)maxone = max(maxone, tmp);j++;}return max(ret, maxone);}};

56. 合并区间

class Solution {
public:static bool cmp(vector<int> a, vector<int> b){if(a[0] !=  b[0]) return a[0] < b[0];if(a[1] !=  b[1]) return a[1] < b[1];return false; }vector<vector<int>> merge(vector< vector<int> > intervals) {vector<vector<int>> ret ;// vector<int> tmp; sort(intervals.begin(), intervals.end(), cmp);int l = intervals[0][0], r = intervals[0][1];for(int i = 1; i< intervals.size(); i++){// cout<<intervals[i][0]<<' '<<intervals[i][1]<<endl;if(intervals[i][0] <= r) r = max(intervals[i][1], r);else {ret.push_back({l, r});l = intervals[i][0];r = intervals[i][1];}}ret.push_back({l, r});return ret;}};

160. 相交链表

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {ListNode* p = headA, *q = NULL;int len1 = 0,len2 = 0;while(p){len1++;p = p->next;}p = headB;while(p){len2 ++;p = p->next;}p = headA;q = headB;if(len1 > len2) {int n = len1 - len2;while(n--) p = p->next;}else{int n = len2 - len1;while(n--) q = q->next;}while(p != q){p = p->next;q = q->next;}return p;}
};

141. 环形链表

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:bool hasCycle(ListNode *head) {set<ListNode *> st;ListNode *p = head;while(p != NULL){if(st.find(p) == st.end()) st.insert(p);else return true;p = p->next;}return false;}
};

142. 环形链表 II

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:ListNode *detectCycle(ListNode *head) {map<ListNode *, int> mp;ListNode * ret = head;int idx = 0;while(ret != NULL){cout<<ret<<' ';if(mp.find(ret) != mp.end())return ret;else mp[ret] = idx++ ;ret = ret->next;}return NULL;}
};



2. 两数相加

/*** 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* addTwoNumbers(ListNode* l1, ListNode* l2) {ListNode* p, *q, *tmp, *tmp2;p = l1;q = l2;int c = 0;tmp2 = p;while(p != NULL && q!=NULL){tmp = p;p->val = p->val + q->val + c;c = p->val / 10;p->val %= 10;p = p->next;q = q->next;}while(p != NULL){tmp = p;p->val += c;c = p->val / 10;p->val %= 10;p = p->next;}if(q!=NULL){tmp->next = q;}while(q != NULL){tmp = q;q->val += c;c = q->val / 10;q->val %= 10;q = q->next;}if(c) {ListNode * x = new ListNode(c, NULL);tmp->next = x;}tmp = reverse(tmp2);tmp2 = reverse(tmp);return tmp2;}ListNode* reverse(ListNode* l1){ListNode* p, *q, *tmp;p = l1 ->next;q = l1;q->next = NULL;while(p != NULL){tmp = p->next;p->next = q;q = p;p = tmp;} return q;}
};

http://www.lryc.cn/news/236247.html

相关文章:

  • 分类预测 | Matlab实现基于SDAE堆叠去噪自编码器的数据分类预测
  • 矩阵运算_矩阵的协方差矩阵/两个矩阵的协方差矩阵_求解详细步骤示例
  • 100天精通Python(可视化篇)——第108天:Pyecharts绘制多种炫酷词云图参数说明+代码实战
  • Spark 平障录
  • 基于一致性算法的微电网分布式控制MATLAB仿真模型
  • Android 10.0 系统修改usb连接电脑mtp和PTP的显示名称
  • 飞鼠异地组网工具实战之访问k8s集群内部服务
  • 【Flink】窗口(Window)
  • 读像火箭科学家一样思考笔记03_第一性原理(上)
  • npm私有云
  • 莹莹API管理系统源码附带两套模板
  • 【Kingbase FlySync】命令模式:安装部署同步软件,实现KES到KES实现同步
  • python使用selenium webDriver时 报错
  • 【ROS2机器人入门到实战】
  • Nuxt3框架局部文件引用外部JS/CSS文件的相关配置方法
  • Docker 可视化面板 ——Portainer
  • Java 教育局民办教育信息服务与监管平台
  • 小迪笔记(1)——操作系统文件下载反弹SHELL防火墙绕过
  • Pytorch D2L Subplots方法对画图、图片处理
  • MATLAB算法实战应用案例精讲-【目标检测】YOLOV5(补充篇)
  • WPF中可视化树和逻辑树的区别是什么
  • 小迪安全笔记(2)——web应用架构搭建漏洞HTTP数据包代理服务器
  • [AI]ChatGPT4 与 ChatGPT3.5 区别有多大
  • node实战——koa实现文件上传
  • C++中的this指针
  • 分析日志的一般套路
  • 使用Flink处理Kafka中的数据_题库子任务_Java语言实现
  • k8s运维管理
  • 【最新Tomcat】IntelliJ IDEA通用配置Tomcat教程(超详细)
  • 安装2023最新版PyCharm来开发Python应用程序