Libraryless. Click here for Pure Java version (2528L/16K).
1 | sclass RollingMaximum { |
2 | int windowSize = 100, i; |
3 | L<Entry> queue = new CircularArrayList; //linkedList(); |
4 | |
5 | sclass Entry { |
6 | int removeIndex; |
7 | double value; |
8 | |
9 | *() {} |
10 | *(int *removeIndex, double *value) {} |
11 | } |
12 | |
13 | *() {} |
14 | *(int *windowSize) {} |
15 | |
16 | double addAndGet(double val) { |
17 | while (nempty(queue) && i >= first(queue).removeIndex) |
18 | popFirst(queue); |
19 | |
20 | while (nempty(queue) && last(queue).value <= val) |
21 | popLast(queue); |
22 | |
23 | queue.add(new Entry(i + windowSize, val)); |
24 | i++; |
25 | ret first(queue).value; |
26 | } |
27 | } |
download show line numbers debug dex old transpilations
Travelled to 6 computer(s): bhatertpkbcr, mqqgnosmbjvj, pyentgdyhuwx, pzhvpgtvlbxg, tvejysmllsmz, vouqrxazstgt
No comments. add comment
Snippet ID: | #1025078 |
Snippet name: | RollingMaximum - using "descending maxima" algorithm [OK] |
Eternal ID of this version: | #1025078/9 |
Text MD5: | b3bea9e67bd5c18f267de7afab46db39 |
Transpilation MD5: | 85be16b767ddb878118b4cd99b539f75 |
Author: | stefan |
Category: | javax / maths |
Type: | JavaX fragment (include) |
Public (visible to everyone): | Yes |
Archived (hidden from active list): | No |
Created/modified: | 2019-09-05 13:24:27 |
Source code size: | 575 bytes / 27 lines |
Pitched / IR pitched: | No / No |
Views / Downloads: | 274 / 738 |
Version history: | 8 change(s) |
Referenced in: | [show references] |