LeetCode每日三题(五)双指针
一、移动零
自己答案:
class Solution {
public void moveZeroes(int[] nums) {
for(int i=0;i<nums.length;i++){
//定义一个计数器
int count=0;
//如果遍历到一个零元素
if(nums[i]==0){
//遍历零元素后面的元素
for(int j=i;j<nums.length;j++){
//发现非零元素,交换顺序并且结束遍历
if(nums[j]!=0){
nums[i]=nums[j];
nums[j]=0;
break;
}else//没有发现则计数器加一
count++;
}
}else if(count==nums.length-i-1){
//如果计数器为数组长度-当前索引值-1,则说明后面没有非零元素
break;
}
}
}
}
标准答案:
class Solution {
public void moveZeroes(int[] nums) {
int n = nums.length, left = 0, right = 0;
while (right < n) {
//若right指针是非零元素
if (nums[right] != 0) {
if(right==left){
//两个指针指向同一个位置
//直接跳过
right++;
left++;
continue;
}else{
//交换元素
nums[left]=nums[right];
nums[right]=0;
//left指针+1
left++;
}
}
//若right指针是零元素,则+1
right++;
}
}
}
二、盛最多水的容器
自己答案:
class Solution {
public int maxArea(int[] height) {
int right=height.length-1;
int left=0;
int result=0;
while(right!=left){
int area=min(height[right],height[left])*(right-left);
if(result<area){
result=area;
}
if(height[right]<height[left]){
right--;
}else{
left++;
}
}
return result;
}
public int min(int i,int j){
if(j>i){
return i;
}else{
return j;
}
}
}
标准答案:
public class Solution {
public int maxArea(int[] height) {
int l = 0, r = height.length - 1;
int ans = 0;
while (l < r) {
int area = Math.min(height[l], height[r]) * (r - l);
ans = Math.max(ans, area);
if (height[l] <= height[r]) {
++l;
}
else {
--r;
}
}
return ans;
}
}
三、三数之和
自己答案:
class Solution {
public List<List<Integer>> threeSum(int[] nums) {
//给整数数组排序
Arrays.sort(nums);
Set<List<Integer>> set=new HashSet<>();
List<List<Integer>> result=new ArrayList<>();
for(int i=0;i<nums.length;i++){
for(int j=i+1;j<nums.length;j++){
int value=-nums[j]-nums[i];
int index = Arrays.binarySearch(nums, j + 1, nums.length, value);
if(index>=0){
//存在
List<Integer> temp=new ArrayList<>();
temp.add(nums[i]);
temp.add(nums[j]);
temp.add(nums[index]);
Collections.sort(temp);
set.add(temp);
}
}
}
for (List<Integer> integers : set) {
List<Integer> list=new ArrayList<>();
for (Integer integer : integers) {
list.add(integer);
}
result.add(list);
}
return result;
}
}
标准答案:
class Solution {
public List<List<Integer>> threeSum(int[] nums) {
Arrays.sort(nums); // 先排序
List<List<Integer>> res = new ArrayList<>();
for (int i = 0; i < nums.length; i++) {
// 跳过重复元素
if (i > 0 && nums[i] == nums[i - 1]) continue;
// 双指针,目标是找到 nums[l] + nums[r] = -nums[i]
int l = i + 1, r = nums.length - 1;
int target = -nums[i];
while (l < r) {
int sum = nums[l] + nums[r];
if (sum == target) {
res.add(Arrays.asList(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--;
} else if (sum < target) {
l++;
} else {
r--;
}
}
}
return res;
}
}
原文地址:https://blog.csdn.net/DDDiccc/article/details/144802411
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!