Leetcode 027 移除元素

https://leetcode.cn/problems/remove-element/description/

/*
 * @lc app=leetcode.cn id=27 lang=cpp
 * @lcpr version=30204
 *
 * [27] 移除元素
 */


// @lcpr-template-start
using namespace std;
#include <algorithm>
#include <array>
#include <bitset>
#include <climits>
#include <deque>
#include <functional>
#include <iostream>
#include <list>
#include <queue>
#include <stack>
#include <tuple>
#include <unordered_map>
#include <unordered_set>
#include <utility>
#include <vector>
// @lcpr-template-end
// @lc code=start
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int l = 0; int r = l;
        while (l < nums.size() && r < nums.size()) {
            while (r < nums.size() && nums[r] == val) r++;
            if (r < nums.size()) {
                nums[l] = nums[r];
                l++; r++;
            }
            else {
                break;
            }
        }

        return l;
    }
};

// @lc code=end



/*
// @lcpr case=start
// [3,2,2,3]\n3\n
// @lcpr case=end

// @lcpr case=start
// [0,1,2,2,3,0,4,2]\n2\n
// @lcpr case=end

 */

posted on 2024-09-11 11:55  itdef  阅读(2)  评论(0编辑  收藏  举报

导航