A soma acumulada de um vetor é calculada simplesmente com a soma de todos os elementos anteriores. Por exemplo:
vec = [1 1 1 -1 -1 -1 -1 -1 1 1 1 1 -1]
cum_vec = [1 2 3 2 1 0 -1 -2 -1 0 1 2 1]
Agora, imponha um limite superior e um inferior, o que significa que você para de aumentar a soma acumulada se estiver no limite superior e para de diminuir a soma acumulada se estiver no limite inferior. Um exemplo simples:
upper_lim = 2
lower_lim = -1
vec = [1 1 1 -1 -1 -1 -1 -1 1 1 1 1 -1]
cum_vec = [1 2 2 1 0 -1 -1 -1 0 1 2 2 1]
O vetor de entrada consiste em números inteiros, não necessariamente apenas 1
e -1
, positivos e negativos. Suponha isso upper_lim >= lower_lim
. Se o primeiro elemento do vetor estiver fora do limite, pule diretamente para o limite (veja o último exemplo).
Escreva uma função que use um vetor de números inteiros como entrada e dois números inteiros que representam os limites superior e inferior. Saída do vetor cumulativo delimitado, conforme definido acima. A entrada pode ser como argumentos de função ou de STDIN.
Aplicam-se as regras de código padrão do golfe.
Exemplos:
upper_lim = 6
lower_lim = -2
vec = [1 4 3 -10 3 2 2 5 -4]
cum_vec = [1 5 6 -2 1 3 5 6 2]
upper_lim = 100
lower_lim = -100
vec = [1 1 1 1 1 1]
cum_vec = [1 2 3 4 5 6]
upper_lim = 5
lower_lim = 0
vec = [10 -4 -3 2]
cum_vec = [5 1 0 2]
upper_lim = 0
lower_lim = 0
vec = [3 5 -2 1]
cum_vec = [0 0 0 0]
upper_lim = 10
lower_lim = 5
vec = [1 4 6]
cum_vec = [5 9 10]
|
Note, jumped to 5, because 5 is the lower bound.
fonte