leetCode - - - 数组

1.移动0(leetcode283)

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

java 复制代码
class Solution {
    public void moveZeroes(int[] nums) {
        int slow=0;
        for(int fast=0;fast<nums.length;fast++){
            if(nums[fast]!=0){
                nums[slow]=nums[fast];
                slow++;
            }
        }
        for(int i=slow;i<nums.length;i++){
            nums[i]=0;
        }
    }
}

2.颜色分类(leetcode75)

给定一个包含红色、白色和蓝色、共 n个元素的数组 nums ,**原地**对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。

我们使用整数 012 分别表示红色、白色和蓝色。

必须在不使用库内置的 sort 函数的情况下解决这个问题。

java 复制代码
class Solution {
    public void sortColors(int[] nums) {
        int left=0;
        int right=nums.length-1;
        int index=0;
        while(index<=right){
           int cur=nums[index];
            if(cur==0){
                swap(nums,index,left);

                //index不能再left的左边
                index++;

                left++;
            }
            if(cur==1){
                index++;
            }
            if(cur==2){
                swap(nums,index,right);
                right--;
                //这里没有index++;因为还不知道num[index]是多少,可能是0,还要往前交换
            }
        }
    }

    //交换
    public void swap(int[] nums,int i,int j){
        int tmp=nums[i];
        nums[i]=nums[j];
        nums[j]=tmp;
    }
 }

3.删除有序数组中的重复项目(leetcode26)

给你一个 非严格递增排列 的数组 nums ,请你**原地** 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。

考虑 nums 的唯一元素的数量为 k ,你需要做以下事情确保你的题解可以被通过:

  • 更改数组 nums ,使 nums 的前 k 个元素包含唯一元素,并按照它们最初在 nums 中出现的顺序排列。nums 的其余元素与 nums 的大小不重要。
  • 返回 k

判题标准:

系统会用下面的代码来测试你的题解:

复制代码
int[] nums = [...]; // 输入数组
int[] expectedNums = [...]; // 长度正确的期望答案

int k = removeDuplicates(nums); // 调用

assert k == expectedNums.length;
for (int i = 0; i < k; i++) {
    assert nums[i] == expectedNums[i];
}

如果所有断言都通过,那么您的题解将被 通过

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {
        //p用来放即将要存储的位置
        int p=0;
        //对数组元素进行遍历
        for(int i=0;i<nums.length;i++){
            if(i==0||nums[i]!=nums[i-1]){
                nums[p]=nums[i];
                p++;
            }
        }
        return p;
    }
}

4.合并两个有序数组(leetcode88)

给你两个按 非递减顺序 排列的整数数组 nums1nums2,另有两个整数 mn ,分别表示 nums1nums2 中的元素数目。

请你 合并 nums2nums1 中,使合并后的数组同样按 非递减顺序 排列。

注意: 最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n

java 复制代码
class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        //设置三个索引,原来num1的末端,原来num2的末端,合并后num1的末端
        int i=m-1;
        int j=n-1;
        int cur=nums1.length-1;

        //num2中元素要全部合并到num1中
        while(j>=0 ){
            if(i>=0 &&nums1[i]>nums2[j]){
                nums1[cur]=nums1[i];
                cur--;
                i--;
            }else{
                nums1[cur]=nums2[j];
                cur--;
                j--;
            }
        }
    }
}

这道题解的很波折 ~~~~

终于明白了 o(╥﹏╥)o

相关推荐
十五年专注C++开发5 分钟前
QT 中的元对象系统(五):QMetaObject::invokeMethod的使用和实现原理
开发语言·数据结构·c++·qt·设计模式
泛舟起晶浪9 分钟前
特殊的质数肋骨--dfs+isp
算法·深度优先
GGBondlctrl9 分钟前
【leetcode】记录与查找:哈希表的题型分析
算法·力扣·两数之和·字母异位词分组·存在重复字符2
视觉AI19 分钟前
研究下适合部署在jeston上的深度学习类单目标跟踪算法
深度学习·算法·目标跟踪
独好紫罗兰1 小时前
洛谷题单3-P1075 [NOIP 2012 普及组] 质因数分解-python-流程图重构
开发语言·python·算法
daily_23332 小时前
coding ability 展开第九幕(位运算——进阶篇)超详细!!!!
算法·位运算
柏木乃一2 小时前
双向链表增删改查的模拟实现
开发语言·数据结构·算法·链表
whltaoin4 小时前
Java实现N皇后问题的双路径探索:递归回溯与迭代回溯算法详解
java·算法
梭七y6 小时前
【力扣hot100题】(032)排序链表
算法·leetcode·链表
SsummerC6 小时前
【leetcode100】数组中的第K个最大元素
python·算法·leetcode