leetcode刷题 java数组基础题
485
485. 最大连续 1 的个数
难度简单250
给定一个二进制数组, 计算其中最大连续 1 的个数。leetcode刷题 java数组基础题
class Solution {
public int findMaxConsecutiveOnes(int[] nums) {
int sum=0;
int high=0;
int i;
int n=nums.length;
for(i=0;i<n;i++){
if(nums[i]==1){
sum++;
if(sum>=high){
high=sum;
}
}
if(nums[i]==0) {
sum=0;
}
}
return high;
}
}
比较简单
283
283. 移动零
难度简单1124
给定一个数组 nums
,编写一个函数将所有 0
移动到数组的末尾,同时保持非零元素的相对顺序。
示例:
输入: [0,1,0,3,12]
输出: [1,3,12,0,0]
说明:
- 必须在原数组上操作,不能拷贝额外的数组。
- 尽量减少操作次数。
思路
第一种:可以暴力求解。用两个for循环。第一层for循环寻找到0的位置。在找到0的位置后,再用一个for循环寻找到距离该0最近的非零元素的位置。接着替换元素数字。由此完成一个循环。
class Solution {
public void moveZeroes(int[] nums) {
int n=nums.length;
if(nums==null){
return;
}
int i;
for(i=0;i<n;i++){
if(nums[i]==0){
int shuzi=0;
for(shuzi=i+1;shuzi<n;shuzi++){
if(nums[shuzi]!=0){
nums[i]=nums[shuzi];
nums[shuzi]=0;
break;
}
}
//i=shuzi-1;
}
}
}
}
第二种:双指针法
我们利用a,b两个指针。a指针是遍历数组。当nums[a]!=0时,nums[b]=nums[a],这样,当a到达末尾时,b所在位置就是0与非零的分界点。然后,在进行一遍循环,将b后面的元素置为0,即可。
class Solution {
public void moveZeroes(int[] nums) {
int n=nums.length;
if(nums==null){
return;
}
int a=0;
int b=0;
while(a<n){
if(nums[a]!=0){
nums[b]=nums[a];
b++;
}
a++;
}
while(b<n){
nums[b]=0;
b++;
}
}
}
27
27. 移除元素
难度简单958
给你一个数组 nums
和一个值 val
,你需要 原地 移除所有数值等于 val
的元素,并返回移除后数组的新长度。
不要使用额外的数组空间,你必须仅使用 O(1)
额外空间并 原地 修改输入数组。
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。
说明:
为什么返回数值是整数,但输出的答案是数组呢?
请注意,输入数组是以**「引用」**方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。
你可以想象内部操作如下:
// nums 是以“引用”方式传递的。也就是说,不对实参作任何拷贝
int len = removeElement(nums, val);
// 在函数里修改输入数组对于调用者是可见的。
// 根据你的函数返回的长度, 它会打印出数组中 该长度范围内 的所有元素。
for (int i = 0; i < len; i++) {
print(nums[i]);
}
代码
与283思路一致
class Solution {
public int removeElement(int[] nums, int val) {
if(nums==null){
return 0;
}
int n=nums.length;
int a=0;
int b=0;
while(a<n){
if(nums[a]!=val){
nums[b]=nums[a];
b++;
}
a++;
}
return b;
}
}
动图源于网络,侵删