由于本周的题目比较简单,又很相似,于是就来上两道吧,两道题的难度级别都是"Easy"
题目:给一个有序的数组,将其按照不重复的数字重新排序,并返回排序后数组的长度(不要为其他的数组开辟新的空间,就在这段数组已占用的内存中操作)
思路:因为C语言没有删除数组的API,所以我一开始是将重复的删掉,把后面不重复的数字往前移,发现效率太低,比python写的效率还低,后来发现其实不需要每发现一个重复的都将其后面的往前移,只要遍历一次,将其重新排序即可,具体看代码:
int removeDuplicates(int* nums, int numsSize) {
if (numsSize <= 1) return numsSize;
//j为新的顺序,因为第0个肯定不会重复,所以从第1个开始
int j = 1;
for (int i = 0; i < numsSize - 1; i++)
//如果不是重复的就将其排在新的位置上
if (nums[i] != nums[i+1]) nums[j++] = nums[i+1];
return j;//由于是j++,所以直接返回新的长度j即可
}
很简单,我们来看下一道
题目:给一个数组和一个特定的数字,删除数组里所有这个数字。重新排序,返回新数组的长度(不要为其他的数组开辟新的空间,就在这段数组已占用的内存中操作)
思路:和上一道基本一样,直接看代码吧:
int removeElement(int* nums, int numsSize, int val) {
//因为这次是和val比较,所以要从第0位开始
int j = 0;
for (int i = 0; i < numsSize; i++)
//如果不等于val,则放到新的位置上
if (nums[i] != val) nums[j++] = nums[i];
return j;
}
此两道题的效率中上。