leetcode上第283号问题:Move Zeros
给定一个数组nums,写一个函数,将数组中所有的0挪到数组的末尾,⽽维持其他所有非0元素的相对位置。
举例: nums = [0, 1, 0, 3, 12],函数运⾏后结果为[1, 3, 12, 0, 0]
思路:创建一个临时数组nonZeroElements,遍历nums,将nums中非0元素赋值到nonZeroElements中,而后按顺序将nonZeroElements赋值到nums上,未遍历的元素置0;
动画如下:
代码如下:
1
2
3class Solution {
4public:
5 void moveZeroes(vector<int>& nums) {
6
7 vector<int> nonZeroElements;
8
9
10 for(int i = 0 ; i < nums.size() ; i ++)
11 if(nums[i])
12 nonZeroElements.push_back(nums[i]);
13
14
15 for(int i = 0 ; i < nonZeroElements.size() ; i ++)
16 nums[i] = nonZeroElements[i];
17
18
19 for(int i = nonZeroElements.size() ; i < nums.size() ; i ++)
20 nums[i] = 0;
21 }
22};
思路:设定一个临时变量k=0,遍历数组nums,将非零元素移动到nums[k]位置,同时k++,而后将【k,….nums.size()】中的元素置零。
动画如下:
1
2
3
4class Solution {
5public:
6 void moveZeroes(vector<int>& nums) {
7
8 int k = 0;
9
10
11
12 for(int i = 0 ; i < nums.size() ; i ++)
13 if(nums[i])
14 nums[k++] = nums[i];
15
16
17 for(int i = k ; i < nums.size() ; i ++)
18 nums[i] = 0;
19 }
20};
思路:设定一个临时变量k=0,遍历数组nums,将非零元素与之前的零元素进行交换,维护变量k的值。
动画如下:
代码如下:
1
2
3
4class Solution {
5public:
6 void moveZeroes(vector<int>& nums) {
7
8 int k = 0;
9
10
11
12
13 for(int i = 0 ; i < nums.size() ; i ++)
14 if(nums[i])
15 if(k != i)
16 swap(nums[k++] , nums[i]);
17 else
18 k ++;
19 }
20};
朋友会在“发现-看一看”看到你“在看”的内容