-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathDsVector.java
More file actions
91 lines (84 loc) · 2.19 KB
/
DsVector.java
File metadata and controls
91 lines (84 loc) · 2.19 KB
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
package datastructures;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Vector;
public class DsVector {
/**
* Adds 1 to each element of the vector
*
* @param arr the vector to be incremented
* @return the incremented vector
*/
public static Vector<Integer> modifyVector(Vector<Integer> v) {
for (int i = 0; i < v.size(); i++) {
v.set(i, v.get(i) + 1);
}
return v;
}
/**
* Searches the vector for all instances of n
*
* @param v the vector to be searched
* @ A vector of all indices where n was found
*/
public static Vector<Integer> searchVector(Vector<Integer> v, int n) {
Vector<Integer> indices = new Vector<Integer>();
for (int i = 0; i < v.size(); i++) {
if (v.get(i) == n) {
indices.add(i);
}
}
return indices;
}
/**
* Sorts the vector in ascending order
*
* @param v the vector to be sorted
* @return the sorted vector
*/
public static Vector<Integer> sortVector(Vector<Integer> v) {
Vector<Integer> ret = new Vector<Integer>(v);
ArrayList<Integer> list = new ArrayList<>(ret);
Collections.sort(list);
ret.clear();
ret.addAll(list);
return ret;
}
/**
* Reverses the vector
*
* @param v the vector to be reversed
* @return the reversed vector
*/
public static Vector<Integer> reverseVector(Vector<Integer> v) {
Vector<Integer> ret = new Vector<Integer>(v);
Collections.reverse(ret);
return ret;
}
/**
* Rotates the vector by n
*
* @param v the vector to be rotated
* @param n the number of times to rotate the vector
* @return the rotated vector
*/
public static Vector<Integer> rotateVector(Vector<Integer> v, int n) {
Vector<Integer> ret = new Vector<Integer>(v);
Collections.rotate(ret, -n);
return ret;
}
/**
* Merges two vectors
*
* @param v1 the first vector to be merged
* @param v2 the second vector to be merged
* @return the merged vector
*/
public static Vector<Integer> mergeVectors(Vector<Integer> v1,
Vector<Integer> v2) {
Vector<Integer> ret = new Vector<Integer>(v1.size() + v2.size());
ret.addAll(v1);
ret.addAll(v2);
return ret;
}
}