美文网首页lintcode程序员
101. 删除排序数组中的重复数字 II

101. 删除排序数组中的重复数字 II

作者: 和蔼的zhxing | 来源:发表于2018-01-30 15:14 被阅读27次

跟进“删除重复数字”:
如果可以允许出现两次重复将如何处理?

允许出现两次重复的意思就是说两次重复不算重复,和一次重复的略有不同,只需要一个计数器来计算是否有两次重复就可以了。

int removeDuplicates(vector<int> &nums) {
        if(nums.empty())
        return 0;
        int i=1;
        int j=0;
        int flag=1;
        for(;i<nums.size();i++)
        {
            if(nums[i]!=nums[j])
            {
                cout<<nums[i]<<" ";
                nums[j+1]=nums[i];
                j++;
                
    
                flag=1;
            }
            else if(nums[i]==nums[j])
            {
                if(flag>=2)
                 continue;
                else
                {
                    nums[j+1]=nums[i];
                    j++;
                    flag++;
                }
                
            }
        }
        nums.reserve(j+1);
        return j+1;
        // write your code here
    }

相关文章

  • leetcode探索初级算法之数组

    推荐:只出现一次的数字,旋转数组,两个数组的交集 II 和 两数之和。 1. 删除排序数组中的重复项 给定一个排序...

  • 101. 删除排序数组中的重复数字 II

    跟进“删除重复数字”:如果可以允许出现两次重复将如何处理? 允许出现两次重复的意思就是说两次重复不算重复,和一次重...

  • LeetCode 82. 删除排序链表中的重复元素 II

    82. 删除排序链表中的重复元素 II 给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出...

  • 82. 删除排序链表中的重复元素 II

    82. 删除排序链表中的重复元素 II 给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出...

  • 顺序表

    1.删除排序数组中的重复数字 给定一个排序数组,在原数组中删除重复出现的数字,使得每个元素只出现一次,并且返回新的...

  • 80. 删除排序数组中的重复项 II

    80. 删除排序数组中的重复项 II 给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素最多出现两次,...

  • lintcode-删除排序数组中的重复数字

    删除排序数组中的重复数字 利用库函数,偷懒法

  • leecode刷题(1)-- 删除排序数组中的重复项

    leecode刷题(1)-- 删除排序数组中的重复项 删除排序数组中的重复项 给定一个排序数组,你需要在原地删除重...

  • 数组

    26 删除排序数组中的重复项 使用双指针的做法,删除排序数组中的重复项其实就是找出排序数组中的非重复项,两个指针,...

  • 3.数组中重复的数字

    找出数组中任意一个重复的数字! 思路1:把数组排序,从排序后的数组中找出重复的数字。但排序一个长度为n的数组需要O...

网友评论

    本文标题:101. 删除排序数组中的重复数字 II

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