Algorithms_in_C++ 1.0.0
Set of algorithms implemented in C++.
|
for std::vector More...
Functions | |
void | print (const std::vector< int32_t > &array) |
Prints the values of a vector sequentially, ending with a newline character. | |
std::vector< int32_t > | shift_left (const std::vector< int32_t > &array, size_t shift) |
Shifts the given vector to the left by the shift amount and returns a new vector with the result. The original vector is not mutated. | |
std::vector< int32_t > | shift_right (const std::vector< int32_t > &array, size_t shift) |
Shifts the given vector to the right by the shift amount and returns a new vector with the result. The original vector is not mutated. | |
std::vector< int32_t > | get_intersection (const std::vector< int32_t > &first, const std::vector< int32_t > &second) |
Gets the intersection of two sorted arrays, and returns them in a vector. | |
std::vector< int32_t > | get_union (const std::vector< int32_t > &first, const std::vector< int32_t > &second) |
Gets the union of two sorted arrays, and returns them in a vector. | |
for std::vector
For std::vector.
for assert for IO operations
Operations on Data Structures
for assert for IO Operations
Operations on data structures
for std::sort for assert for IO operations
Operations on Data Structures
For assert For IO operations For std::queue
Operations on Data Structures
for std::count for assert for tolower for string operations for IO Operations
Operations on data structures
std::vector< int32_t > operations_on_datastructures::get_intersection | ( | const std::vector< int32_t > & | first, |
const std::vector< int32_t > & | second ) |
Gets the intersection of two sorted arrays, and returns them in a vector.
An algorithm is used that compares the elements of the two vectors, incrementing the index of the smaller of the two. If the elements are the same, the element is appended to the result array to be returned.
first | A std::vector of sorted integer values |
second | A std::vector of sorted integer values |
< Vector to hold the intersection
< Index for the first array
< Index for the second array
< Length of first array
< Length of second array
< Increment index of second array
< Increment index of second array
< Add the element if it is unique
< Increment index of first array
< Increment index of second array too
std::vector< int32_t > operations_on_datastructures::get_union | ( | const std::vector< int32_t > & | first, |
const std::vector< int32_t > & | second ) |
Gets the union of two sorted arrays, and returns them in a vector.
An algorithm is used that compares the elements of the two vectors, appending the one that has a lower value, and incrementing the index for that array. If one of the arrays reaches its end, all the elements of the other are appended to the resultant vector.
first | A std::vector of sorted integer values |
second | A std::vector of sorted integer values |
< Vector to hold the union
< Index for the first array
< Index for the second array
< Length of first array
< Length of second array
< Integer to store value of the next element
< Append from first array
< Increment index of second array
< Append from second array
< Increment index of second array
< Element is the same in both
< Increment index of first array
< Increment index of second array too
< Add the element if it is unique
< Add remaining elements
< Add the element if it is unique
< Add remaining elements
< Add the element if it is unique
void operations_on_datastructures::print | ( | const std::vector< int32_t > & | array | ) |
Prints the values of a vector sequentially, ending with a newline character.
array | Reference to the array to be printed |
Print each value in the array
Print newline
Print each value in the array
Print newline
Print each value in the array
Print newline
Print each value in the array
Print newline
Print each value in the array
Print newline
Print each value in the array
Print newline
Print each value in the array
Print newline
std::vector< int32_t > operations_on_datastructures::shift_left | ( | const std::vector< int32_t > & | array, |
size_t | shift ) |
Shifts the given vector to the left by the shift amount and returns a new vector with the result. The original vector is not mutated.
Shifts the values of the vector, by creating a new vector and adding values from the shift index to the end, then appending the rest of the elements from the start of the vector.
array | A reference to the input std::vector |
shift | The amount to be shifted to the left |
< We got an invalid shift, return empty array
< Result array
< Add values after the shift index
< Add the values from the start
std::vector< int32_t > operations_on_datastructures::shift_right | ( | const std::vector< int32_t > & | array, |
size_t | shift ) |
Shifts the given vector to the right by the shift amount and returns a new vector with the result. The original vector is not mutated.
Shifts the values of the vector, by creating a new vector and adding values from the shift index to the end, then appending the rest of the elements to the start of the vector.
array | A reference to the input std::vector |
shift | The amount to be shifted to the right |
< We got an invalid shift, return empty array
< Result array
< Add values after the shift index
< Add the values from the start