given array a, calculate new array b of size n, such b[i] = min (0 ≤ j ≤i) a[j]. in other words, b[i] should store minimum element in subarray of indices 0 i, inclusive.
input: a[7, 3, 4, 2, 15, 11, 16, 7, 18, 9, 11, 10]
output: b[7, 3, 3, 2, 2, 2, 2, 2, 2, 2, 2, 2]
i'm trying create efficient algorithm solving problem. attempt @ psuedocode.
minelement(a): b[n]; //empty array for(i = 0; < a.length()-1; i++) if(a[i] < in b[]) b[i] = a[i]
i'm having hard time trying implement logic.
you need variable currentmin
keep track of minimum value in portion of input array processed.
func calculate(nums:[int]) -> [int] { guard !nums.isempty else { return [] } var currentmin = nums[0] var output: [int] = [] num in nums { currentmin = min(currentmin, num) output.append(currentmin) } return output }
so inside loop can update currentmin
variable , append value output.
the provided implementation in swift.
Comments
Post a Comment