day4 removeElement & nextPer

2016-08-22  本文已影响8人  陈十十

1] Remove Element

    int removeElement(vector<int>& nums, int val) {
        int nextWritter = -1;
        for (int scanner=0; scanner<nums.size(); ++scanner) {
            if (nums[scanner]!=val) {
                nums[++nextWritter] = nums[scanner];
            }
        }
        return nextWritter+1;
    }

or

    int removeElement(vector<int>& nums, int val) {
        return distance( nums.begin(), remove(nums.begin(), nums.end(), val) );
    }

2] Next Permutation
一开始没有找清楚规律,看好pivot之右是什么情况,为什么

    void nextPermutation(vector<int>& nums) {
        if (nums.size() < 2) return;
        for (auto r=nums.end()-1; r>nums.begin(); --r) {
            if (*(r-1) < *r){
                auto pivot = r-1;
                for (auto i=nums.end()-1; i>=r; --i) {
                    if (*i>*pivot) {
                        swap(*i, *pivot); //CAREFUL NOT TO SWAP ITERATOR
                        reverse(pivot+1, nums.end());
                        return;
                    }
                }
            }
        }
        reverse(nums.begin(), nums.end());
        return;
    }
上一篇下一篇

猜你喜欢

热点阅读