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

由于本周的题目比较简单,又很相似,于是就来上两道吧,两道题的难度级别都是"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 原创出品,欢迎转载,转载时请注明出处!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,237评论 0 52
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,753评论 0 15
  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 5,257评论 0 12
  • 2017年5月15号,太原,多云 今天是周末,一早带着芃芃去动物园了,玩了一天,虽然累,但是也挺开心的,下午回来买...
    七里咔嚓阅读 448评论 0 0
  • 一、view封装的思路: *如果一个view内部的子控件比较多,一般会考虑自定义一个view,把它内部的子控件的创...
    鱼与熊掌不能兼得阅读 403评论 0 0