Supponiamo di avere un elenco di intervalli (ordinati per inizio) e di suddividerli in modo da avere un elenco di gruppi di intervalli sovrapposti. Così, per esempio, con Interval
come:Elenco di partizioni Java 8 in gruppi in base a elementi precedenti
public class Interval {
private final int start;
private final int end;
public Interval(int start,int end){
this.start = start;
this.end = end;
}
public int getStart(){return start;}
public int getEnd(){return end;}
public String toString(){ return "("+start+","+end+")"; }
}
E un List<Interval>
come:
[(0,4),(1,7),(6,10),(13,17),(20,100),(22,31),(60,65)]
voglio una potenza di List<List<Interval>>
:
[[(0,4),(1,7),(6,10)],[(13,17)],[(20,100),(22,31),(60,65)]]
posso codice questo in su, ma io Mi sto davvero godendo l'approccio più funzionale di Java 8 e voglio sapere se c'è qualcosa di simile a un modo idiomatico per farlo usando i flussi Java 8.
Ho dato uno sguardo agli stili "raggruppati" di Collectors forniti, ma non sembrano applicabili poiché non sto realmente raggruppando per un classificatore- non è possibile calcolare i gruppi basati solo su una proprietà di ogni singolo elemento, devi considerare le proprietà di ogni elemento in relazione ai gruppi che sono stati calcolati finora.
Certamente non esiste un modo non folle di farlo in linguaggi funzionali (anche se parlo come qualcuno che non è realmente un programmatore funzionale :-)). Come posso farlo con i flussi in Java 8?
Immagino che 'this.start = end;' non è quello che vuoi. Ma è una buona cosa che tu stia usando le variabili 'final' in modo che l'errore sia immediatamente individuato dal compilatore. – Holger
A proposito, quale dovrebbe essere l'output quando l'input è il seguente: '[(60, 65), (22, 31), (20, 100)]'? Dovrebbero essere uniti tutti e tre gli intervalli? In altre parole, l'ordine degli intervalli di input può modificare il risultato? –
@Tagir Valeev: il prerequisito della domanda (nella prima frase) è che gli elementi sono ordinati in base al loro punto di partenza. Risolvere facilmente questo requisito è possibile anticipando una fase di ordinamento a qualsiasi soluzione. – Holger