首页 > 移动平台 > 详细

lintcode539 移动零

时间:2017-10-06 20:26:08      阅读:297      评论:0      收藏:0      [点我收藏+]

移动零 

给一个数组 nums 写一个函数将 0 移动到数组的最后面,非零元素保持原数组的顺序

 注意事项

1.必须在原数组上操作
2.最小化操作数

样例

给出 nums = [0, 1, 0, 3, 12], 调用函数之后, nums =[1, 3, 12, 0, 0].

 

 1 class Solution {
 2 public:
 3     /*
 4      * @param nums: an integer array
 5      * @return:
 6      */
 7     void moveZeroes(vector<int>& nums) {
 8         // write your code here
 9         vector<int> res;
10         int len = nums.size();
11         if (0 == len) return;
12         for (int i = 0; i < len; i++) {
13             if (nums[i] != 0) {
14                 res.push_back(nums[i]);
15             }
16         }
17         for (int i = res.size(); i < len; i++) {
18             res.push_back(0);
19         }
20         nums = res;
21     }
22 };

 

lintcode539 移动零

原文:http://www.cnblogs.com/gousheng/p/7632601.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!