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
,**原地**对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。
我们使用整数 0
、 1
和 2
分别表示红色、白色和蓝色。
必须在不使用库内置的 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)
给你两个按 非递减顺序 排列的整数数组 nums1
和 nums2
,另有两个整数 m
和 n
,分别表示 nums1
和 nums2
中的元素数目。
请你 合并 nums2
到 nums1
中,使合并后的数组同样按 非递减顺序 排列。
注意: 最终,合并后数组不应由函数返回,而是存储在数组 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