每周一道算法题(二十二)

作者: CrazySteven | 来源:发表于2017-08-12 15:44 被阅读557次

由于本周的题目比较简单,又很相似,于是就来上两道吧,两道题的难度级别都是"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;
}

此两道题的效率中上。

版权声明:本文为 Crazy Steven 原创出品,欢迎转载,转载时请注明出处!

相关文章

  • ARTS第三周(2018-12-16)

    1.Algorithm:每周至少做一个 leetcode 的算法题 第一道算法题:https://leetcode...

  • ARTS(09)

    什么是 ARTS? 算法(Algorithm): 每周至少一道 LeetCode 算法题,加强编程训练和算法学习 ...

  • ARTS(05)

    什么是 ARTS? 算法(Algorithm): 每周至少一道 LeetCode 算法题,加强编程训练和算法学习 ...

  • ARTS(07)

    什么是 ARTS? 算法(Algorithm): 每周至少一道 LeetCode 算法题,加强编程训练和算法学习 ...

  • ARTS(10)

    什么是 ARTS? 算法(Algorithm): 每周至少一道 LeetCode 算法题,加强编程训练和算法学习 ...

  • ARTS(02)

    什么是 ARTS? 算法(Algorithm): 每周至少一道 LeetCode 算法题,加强编程训练和算法学习 ...

  • ARTS(03)

    什么是 ARTS? 算法(Algorithm): 每周至少一道 LeetCode 算法题,加强编程训练和算法学习 ...

  • ARTS(08)

    什么是 ARTS? 算法(Algorithm): 每周至少一道 LeetCode 算法题,加强编程训练和算法学习 ...

  • ARTS(06)

    什么是 ARTS? 算法(Algorithm): 每周至少一道 LeetCode 算法题,加强编程训练和算法学习 ...

  • ARTS(04)

    什么是 ARTS? 算法(Algorithm): 每周至少一道 LeetCode 算法题,加强编程训练和算法学习 ...

网友评论

    本文标题:每周一道算法题(二十二)

    本文链接:https://www.haomeiwen.com/subject/rgljrxtx.html