码迷,mamicode.com
首页 > 移动开发 > 详细

Find All Numbers Disappeared in an Array

时间:2016-11-01 07:39:57      阅读:304      评论:0      收藏:0      [点我收藏+]

标签:for   code   put   run   without   res   rect   turn   break   

Given an array of integers, 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others appear once.

Find all the elements of [1, n] inclusive that do not appear in this array.

Could you do it without extra space and in O(n) runtime?

Example:

Input:

[4,3,2,7,8,2,3,1]

Output:

[5,6]

 

 1 class Solution {
 2 public:
 3     vector<int> findDisappearedNumbers(vector<int>& nums) {
 4         // put all numbers in correct positions 
 5         for (int i = 0; i < nums.size(); i++) {
 6             while (nums[i] != -1 && i != nums[i] - 1) {
 7                 if (nums[i] == nums[nums[i] - 1]) {
 8                     nums[i] = -1;
 9                     break;
10                 }
11                 swap(nums[i], nums[nums[i] - 1]);
12             }
13         }
14         
15         // put all vacant numbers into the result array
16         vector<int> result;
17         for (int i = 0; i < nums.size(); i++) {
18             if (nums[i] == -1)
19                 result.push_back(i + 1);
20         }
21         return result;
22     }
23 };

 

Find All Numbers Disappeared in an Array

标签:for   code   put   run   without   res   rect   turn   break   

原文地址:http://www.cnblogs.com/amazingzoe/p/6018124.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!