leetcode刷题记录——数组与矩阵
2021-01-17 04:13
标签:数组元素 最大值 数字 contain arch OLE oid 重复 str @ 开始的想法是把零都挪到后面,看到了一种效率更高的写法,思路是先遍历一遍数组,把遇到的非零数按顺序重新复制,后面的全修改成零 遍历 双指针法 因为每一行递增,每一列递增。 所以本题的思路是从右上角往左下角找或者从左下角往右上角找。每次比较可以排除一行或者一列,时间复杂度为O(m+n) 二分查找法 开始的想法是先排序,这种方法时间复杂度为 O(NlogN)。但是可以通过交换数组元素,使得数组上的元素在正确的位置上。这样的话时间复杂度为O(N), 双指针解法要比二分法效率高 1.形成局部环(循环起始点不是初始点) 解决办法:由于情况2比较难处理(因为要判断剩余的结点是哪些),因此这里有一个小小的tips,我们不再是从结点1到结点n中任意位置起跳,而是从结点nums[ 0 ]起跳,这样即使形成的是全局环,循环的起点依然是重复数字(因为全局环意味着环内的末节点指向初始结点,而结点0又指向初始结点,因此,初始结点即循环起始点就是重复数字)。这样,无论情况1还是情况2,我们只需要找到循环起始点就可以了。 作者:shi-wen 使用HashMap 每个元素都跟左上角元素比较,因为第0行和第0列都没有左上角元素,所以两个索引都从1开始。 将访问过的数标位-1,访问到-1直接跳出。原理是如果访问到之前一个循环中访问过的数,则说明也进入了之前的循环,没有必要再进行下去。 leetcode刷题记录——数组与矩阵 标签:数组元素 最大值 数字 contain arch OLE oid 重复 str 原文地址:https://www.cnblogs.com/xiuzhublog/p/12919903.html
283. 移动零
public void moveZeroes(int[] nums) {
int idx = 0;
for (int num : nums) {
if (num != 0) {
nums[idx++] = num;
}
}
while (idx
566. 重塑矩阵
class Solution {
public int[][] matrixReshape(int[][] nums, int r, int c) {
int m = nums.length, n = nums[0].length;
if (m * n != r * c) {
return nums;
}
int[][] reshapedNums = new int[r][c];
int index = 0;
for (int i = 0; i
485. 最大连续1的个数
class Solution {
public int findMaxConsecutiveOnes(int[] nums) {
int front = 0;
int last = 0;
int res = 0;
while (last
240. 搜索二维矩阵 II
和之前剑指offer上的一个题差不多
https://blog.csdn.net/hide_on_rush/article/details/105165885class Solution {
public boolean searchMatrix(int[][] matrix, int target) {
if (matrix == null || matrix.length == 0 || matrix[0].length == 0) return false;
int m = matrix.length, n = matrix[0].length;
int row = 0, col = n - 1;
while (row = 0) {
if (target == matrix[row][col]) return true;
else if (target
378. 有序矩阵中第K小的元素
public int kthSmallest(int[][] matrix, int k) {
int m = matrix.length, n = matrix[0].length;
int lo = matrix[0][0], hi = matrix[m - 1][n - 1];
while (lo
645. 错误的集合
空间复杂度为O(1)。class Solution {
public int[] findErrorNums(int[] nums) {
for (int i = 0; i
287. 寻找重复数
题解里找到的思路:
这里一共有n+1个元素,且元素的值为 [ 1 , n ],因此这里把下标i当做结点的标志,nums[ i ]当做是结点i的下一个结点的标志。这样从结点1到结点n中的任一个结点开始跳,必然会出现两种情况:
2.形成全局环(循环起始点是初始点)
情况1:如果是局部环,那么循环起始点的标志就是重复数字。
情况2:如果是全局环,则稍微复杂一点,因为它只能说明环内的结点所对应的值不重复,但整个全局环不一定包含所有结点。为了判断是否含有重复,还需要从剩下的点继续跳。
链接:https://leetcode-cn.com/problems/find-the-duplicate-number/solution/kuai-man-zhi-zhen-de-yuan-li-0ms-100-by-shi-wen/public int findDuplicate(int[] nums) {
int slow = nums[0], fast = nums[nums[0]];
while (slow != fast) {
slow = nums[slow];
fast = nums[nums[fast]];
}
fast = 0;
while (slow != fast) {
slow = nums[slow];
fast = nums[fast];
}
return slow;
}
667. 优美的排列 II
class Solution {
public int[] constructArray(int n, int k) {
int[] ret = new int[n];
ret[0] = 1;
for (int i = 1, interval = k; i
697. 数组的度
class Solution {
public int findShortestSubArray(int[] nums) {
Map
766. 托普利茨矩阵
class Solution {
public boolean isToeplitzMatrix(int[][] matrix) {
for(int i = 1; i
565. 数组嵌套
class Solution {
public int arrayNesting(int[] nums) {
int res = 0;
for(int i = 0; i
769. 最多能完成排序的块
class Solution {
public int maxChunksToSorted(int[] arr) {
if (arr == null) return 0;
int ret = 0;
int right = arr[0];
for (int i = 0; i
上一篇:最短路——dijkstra算法
下一篇:守护进程-线程