这个我没有做出来,分享大佬的做法:
public int RemoveDuplicates(int[] nums)
{
//边界条件判断
if (nums == null || nums.Length == 0)
return 0;
int left = 0;
for (int right = 1; right < nums.Length; right++)
//如果左指针和右指针指向的值一样,说明有重复的,
//这个时候,左指针不动,右指针继续往右移。如果他俩
//指向的值不一样就把右指针指向的值往前挪
if (nums[left] != nums[right])
nums[++left] = nums[right];
return ++left;
}
总体思路就是,左指针负责确定当前不重复数组范围,右指针用来选择未进行对比的数,很牛的思路
感想:真的每天都在被智商碾压,每天我都觉得昨天那道题这么难,我都看懂了,今天的我应该没问题了,结果好难,然后我就看评论区大佬们的答案,简洁、优雅、高效、神奇的一匹,我就在想,这是人脑子能想出来的东西?然后我现在在想,我天天这样学,坚持下去,应该也能这么厉害吧,哈哈