Get Distinct Goodness Values
A coding competition organized to hire software developers includes an interesting problem on Bitwise-OR. The goodness of a sequence is defined as the bitwise-OR of its elements. Given an array arr of length n, find all possible distinct values of goodness that can be obtained by choosing any strictly increasing subsequence of the array. Sort the return array in non-decreasing order.
Note: A subsequence is a sequence that can be derived from the given sequence by deleting zero or more elements without changing the order of the remaining elements.
Complete the function getDistinctGoodnessValues in the editor below.
getDistinctGoodnessValues has the following parameter:
int arr[n]: an array of integers
Returns
int[]: all possible distinct values of goodness
1Example 1
The strictly increasing subsequences which can be chosen to have distinct goodness values are:
- Empty subsequence; goodness = 0
- [1]; goodness = 1
- [2]; goodness = 2
- [4]; goodness = 4
- (2, 4); goodness = 6
2Example 2
The strictly increasing subsequences which can be chosen to have distinct goodness values are:
- Empty subsequence; goodness = 0
- [2]; goodness = 2
- [3]; goodness = 3
- [4]; goodness = 4
- [6]; goodness = 6
- (3, 4); goodness = 7
3Example 3
The strictly increasing subsequences which can be chosen to have distinct goodness values are:
- Empty subsequence; goodness = 0
- [1]; goodness = 1
- [3]; goodness = 3
- [5]; goodness = 5
- (3, 5); goodness = 7