每日两题 / 15. 三数之和 73. 矩阵置零(LeetCode热题100)

15. 三数之和 - 力扣(LeetCode)
image.png

先确定一个数t,对于剩下的两个数,要求两数之和为t的负数
三数之和就退化成了两数之和,两数之和可以用双指针
先排序,左右两个指针,指向的数之和大于目标值,则r–,反之l++
两数之和为目标值的组合可能不止一对,所以双指针需要走到l == r时停止
根据题目要求,确定两数之和为目标值后,两个指针都需要跳过相同的数,才能继续走
同时,每次双指针的目标值也不能相同
最后,左指针不能从数组的0下标开始,应该从t的后一位开始。这样就能保证每次枚举的三元组都是从小到大排序,不会出现重复的情况

class Solution {
public:vector<vector<int>> threeSum(vector<int>& nums) {sort(nums.begin(), nums.end());vector<vector<int>> ans;for (int i = 0; i < nums.size(); ++ i){if (i && nums[i] == nums[i - 1]) continue;int l = i + 1, r = nums.size() - 1;int t = -nums[i];while (l < r){if (l == i) { l ++ ; continue; }if (r == i) { r -- ; continue; }if (nums[l] + nums[r] < t) l ++ ;else if (nums[l] + nums[r] > t) r -- ;else {ans.push_back({nums[i], nums[l], nums[r]});l ++ , r -- ;while (l < r && nums[l] == nums[l - 1]) l ++ ;while (l < r && nums[r] == nums[r + 1]) r -- ;}}}return ans;}
};

73. 矩阵置零 - 力扣(LeetCode)
image.png

用两个数组维护哪些行/哪些列出现了0,如果第i行/列出现了0,将第i个元素置0
直接将原数组的第0行的第0列作为这两个数组,此时直接修改第0行/第0列的元素为0不会影响答案
问题是:需要确定第0行/第0列是否已经存在0,若存在则需要将整行/整列置0
所以需要使用bool变量先记录这两个数组是否存在0

class Solution {
public:void setZeroes(vector<vector<int>>& matrix) {int row = matrix.size(), col = matrix[0].size();bool r = false, c = false;for (int i = 0; i < col; ++ i) if (!matrix[0][i])r = true;for (int i = 0; i < row; ++ i)if (!matrix[i][0])c = true;for (int i = 1; i < row; ++ i)for (int j = 1; j < col; ++ j)if (!matrix[i][j])matrix[i][0] = 0, matrix[0][j] = 0;for (int i = 1; i < row; ++ i)for (int j = 1; j < col; ++ j)if (!matrix[i][0] || !matrix[0][j])matrix[i][j] = 0;for (int i = 0; r && i < col; ++ i)matrix[0][i] = 0;for (int i = 0; c && i < row; ++ i)matrix[i][0] = 0;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/623484.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

llama_factory微调QWen1.5

GitHub - hiyouga/LLaMA-Factory: Unify Efficient Fine-Tuning of 100 LLMsUnify Efficient Fine-Tuning of 100 LLMs. Contribute to hiyouga/LLaMA-Factory development by creating an account on GitHub.https://github.com/hiyouga/LLaMA-FactoryQwen1.5 介绍 | QwenGITH…

考研数学|基础阶段做什么题,1800/1000/880/660?

基础阶段关键的不是做什么题&#xff0c;关键的是做题 不管你是做1800题还是做87-08年的老真题&#xff0c;任选一个都不会错&#xff0c;只要你静下心去做就行&#xff0c;不要朝三暮四&#xff0c;听别人说1800题好&#xff0c;就去做1800题&#xff0c;听别人说660题好&…

ubuntu系统CMAKE-3.29安装

下载包 https://cmake.org/download/下载后解压&#xff0c;运行./configure按照提示&#xff0c;输入&#xff1a;make 等待结束&#xff0c;然后输入&#xff1a;sudo make install 使用命令 &#xff1a;cmake --version

一篇文章详解深度学习正则化方法(L1、L2、Dropout正则化相关概念、定义、数学公式、Python代码实现)

目录 一、什么是正则化&#xff1f; 二、正则化的作用&#xff1f; 三、常见的正则化方法 四、详解L1正则化 五、详解L2正则化 六、详解Dropout方法 总结&#xff1a; 博主介绍&#xff1a;✌专注于前后端、机器学习、人工智能应用领域开发的优质创作者、秉着互联网精神开源贡…

【数据结构与算法】最大公约数与最小公倍数

最大公因数&#xff08;英语&#xff1a;highest common factor&#xff0c;hcf&#xff09;也称最大公约数&#xff08;英语&#xff1a;greatest common divisor&#xff0c;gcd&#xff09;是数学词汇&#xff0c;指能够整除多个非零整数的最大正整数。例如8和12的最大公因数…

2.4G漂移小车电子方案 酷得智能科技

漂移高速遥控车是一种专门设计用于执行高速漂移动作的遥控车模型。以下是一些关于漂移高速遥控车的功能介绍&#xff1a; 1、高速性能&#xff1a;漂移车通常配备有强力的电机和电池&#xff0c;以便在保持高速的同时进行漂移动作。 2、漂移能力&#xff1a;漂移车的轮胎和悬挂…

springboot同时支持jsp+vue页面启动

1、参考文档链接 参考上面文档边百度边改&#xff0c;现在可以了&#xff0c;分享下 2、Java项目目录结构 3、pom.xml内容 <?xml version"1.0" encoding"UTF-8"?><project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi&quo…

dbever可视化工具使用

分别遵循 1 2 3步骤 可以查看除了执行后的控制台以外的其他窗口。

波分设备的功能和应用

波分设备主要利用光波在光纤中传输数据&#xff0c;具有以下功能&#xff1a; 高速数:据传输。波分技术能提供比传统电信技术更高的数据传输速度。 大带宽:通过将不同频率的光波分配到不同的频段中&#xff0c;波分技术使得更多数据可以同时传输。低衰减&#xff1a;光波在光…

Java——封装、访问修饰符、包

目录 一.封装的概念 二.访问限定符 三.封装扩展之包 1.包的概念 2.导入包中的类 3.自定义包 4.包的访问权限控制举例 5.常见的包 一.封装的概念 面向对象程序三大特性&#xff1a;封装、继承、多态。而类和对象阶段&#xff0c;主要研究的就是封装特性。何为封装呢&am…

electron项目打包慢、打包报错

项目使用了electron框架&#xff0c;在第一次打包或者网络条件不好的环境下进行打包时熟速度慢的出奇&#xff0c;甚至经常出现打包失败的情况&#xff08;如上面图片的报错&#xff09;。 这是因为&#xff0c;在electron打包的过程中&#xff0c;需要去官方源https://github.…

如何在 VM 虚拟机中安装 OpenEuler 操作系统保姆级教程(附链接)

一、VMware Workstation 虚拟机 若没有安装虚拟机的可以参考下篇文章进行安装&#xff1a; 博客链接https://eclecticism.blog.csdn.net/article/details/135713915 二、OpenEuler 镜像 点击链接前往官网 官网 选择第一个即可 三、安装 OpenEuler 打开虚拟机安装 Ctrl …