-
Notifications
You must be signed in to change notification settings - Fork 506
/
Copy pathValue equal to index value.cpp
42 lines (35 loc) · 1.15 KB
/
Value equal to index value.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/*
Value equal to index value
==========================
Given an array Arr of N positive integers. Your task is to find the elements whose value is equal to that of its index value.
Example 1:
Input:
N = 5
Arr[] = {15, 2, 45, 12, 7}
Output: 2
Explanation: Only Arr[2] = 2 exists here.
Example 2:
Input:
N = 1
Arr[] = {1}
Output: 1
Explanation: Here Arr[1] = 1 exists.
Your Task:
You don't need to read input or print anything. Your task is to complete the function valueEqualToIndex() which takes the array of integers arr[] and n as parameters and returns an array of indices where the given conditions are satified. When there is not such element exists then return an empty array of length 0.
Expected Time Complexity: O(N)
Expected Auxiliary Space: O(1)
Note: There can be more than one element in the array which have same value as their index. You need to include every such element's index. Follows 1-based indexing of the array.
Constraints:
1 ≤ N ≤ 105
1 ≤ Arr[i] ≤ 106
*/
vector<int> valueEqualToIndex(int arr[], int n)
{
vector<int> ans;
for (int i = 0; i < n; ++i)
{
if (i + 1 == arr[i])
ans.push_back(i + 1);
}
return ans;
}