0-1 Contatore di fase massimo


21

Considera una serie di bit, diciamo

1 1 1 0 0 0 0 1 0 0 1 0 1 1 1 1 1 0 1 0

Chiamiamo un sottosray contiguo di lunghezza ≥ 5 una fase se almeno l'85% dei bit sono uguali e il primo / ultimo bit sono entrambi uguali al bit maggioritario. Inoltre, chiamiamo una fase massima se non è un sottoarray rigoroso di qualche altra fase.

Ecco le fasi massime dell'esempio sopra:

1 1 1 0 0 0 0 1 0 0 1 0 1 1 1 1 1 0 1 0
      -------------
                    -------------
                        -------------

Come puoi vedere, ci sono 3fasi massime. D'altra parte, questo

1 1 1 0 0 0 0 1 0 0 1 0 1 1 1 1 1 0 1 0
                        ---------

non è una fase massima in quanto è un sottoarray rigoroso di almeno un'altra fase.

La sfida

L'ingresso è una sequenza di ≥ 5 bit tramite STDIN, riga di comando o argomento della funzione. I bit possono entrare come una stringa o un array.

Devi generare un unico numero intero, il numero di fasi massime per l'array, stampato tramite STDOUT o restituito da una funzione.

punteggio

Questo è code-golf, quindi vince il programma nel minor numero di byte.

Casi test

0 1 0 1 0 -> 0
0 0 0 0 0 -> 1
0 0 0 0 1 0 1 1 1 1 -> 0
0 0 0 0 0 1 0 1 1 1 1 1 -> 2
1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 -> 1
0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 1 0 -> 2
0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 -> 1
0 1 0 1 0 0 1 0 1 0 1 0 0 0 1 1 1 1 0 1 0 0 1 1 0 0 0 1 1 0 -> 0
1 1 1 1 1 0 0 0 0 0 1 1 1 1 1 0 0 1 0 0 0 0 0 0 0 0 1 1 0 1 -> 4
0 1 1 0 0 0 0 0 0 0 0 0 0 0 1 0 1 1 1 1 1 1 1 0 1 0 0 0 0 0 -> 5

Ecco la spiegazione per l'ultimo caso:

0 1 1 0 0 0 0 0 0 0 0 0 0 0 1 0 1 1 1 1 1 1 1 0 1 0 0 0 0 0
---------------------------
      -------------------------
                            -----------------
                                -----------------
                                              -------------

Curiosità: questa sfida è nata da un problema di data mining con l'obiettivo di rilevare il cambiamento dei dati temporali.


Domanda su quando si tratta di un subarray contiguo. lunghezza ≥ 5 una fase se almeno l'85% dei bit è lo stesso Diciamo che abbiamo una lunghezza 5 come l' 1 1 0 1 185% di 5 è 4.25 che è Quindi la lunghezza 5 sarebbe impossibile o dovremmo arrotondare a 4?
Teun Pronk,

@TeunPronk Significa che la lunghezza 5 è impossibile a meno che tutti i bit siano uguali
Sp3000

Stavo per modificare il mio commento per aggiungerlo, quindi non è necessario arrotondare per difetto :)
Teun Pronk

Quindi hai intenzione di trovare il maggior numero possibile di subarray o di trovare array il più grandi possibile? perché ne trovo più di 1 nella testcase 5 (non per codice ma guardando)
Teun Pronk,

@TeunPronk devi trovare il maggior numero possibile che non sono interamente contenuti in quelli più grandi. Esiste un solo array per il 5 ° caso di test, a partire dal primo 0e finendo all'ultimo.
Martin Ender,

Risposte:



8

Python 2, 149 byte

a=input()
l=len(a)
n=p=0
for i in range(l):
 for j in range(l-1,i+3,-1):
  if(j>p)>(.15<sum(a[i:j+1])/(j+1.-i)+a[i]+a[j]<2.85):n+=1;p=j;break
print n

Il primo ciclo esegue la scansione dell'array da sinistra a destra. Ogni bit, indicizzato da i, viene controllato per vedere se potrebbe essere il primo bit in una fase massima.

Questo viene fatto dal circuito interno, che esegue la scansione da destra a sinistra. Se il subarray tra ied jè una fase, aumentiamo il contatore e andiamo avanti. Altrimenti, continuiamo fino a quando il subarray non diventa troppo piccolo o j raggiunge la fine della precedente fase massima.

1 1 1 0 0 0 0 1 0 0 1 0 1 1 1 1 1 0 1 0
i ->                               <- j

Esempio:

$ python phase.py
[1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0]
3

5

Python 2, 144

Inserisci l'input nel modulo [0,1,0,1,0].

a=input()
o=[2];i=-1
while a[i:]:
 j=len(a);i+=1
 while j>i+4:o+=sum(j>max(o)>x==a[i]==a[j-1]for x in a[i:j])*20/(j-i)/17*[j];j-=1
print~-len(o)

Le successive sono verificate con l'ordinamento aumentando l'elemento iniziale, quindi diminuendo la lunghezza. In questo modo, è noto che una nuova sottosequenza non è una sottosequenza di una sottosequenza precedente se l'indice del suo ultimo elemento è maggiore di qualsiasi indice dell'ultimo elemento di una sequenza trovata in precedenza.


4

Dyalog APL, 86 byte *

{+/∨/¨∪↓∨⍀∨\{⊃({(.5>|k-⍵)∧.35≤|.5-⍵}(+/÷⍴)⍵)∧(5≤⍴⍵)∧(⊃⌽⍵)=k←⊃⍵}¨⌽∘.{(⍺-1)↓⍵↑t}⍨⍳⍴t←⍵}

Provalo qui. Uso:

   f ← {+/∨/¨∪↓∨⍀∨\{⊃({(.5>|k-⍵)∧.35≤|.5-⍵}(+/÷⍴)⍵)∧(5≤⍴⍵)∧(⊃⌽⍵)=k←⊃⍵}¨⌽∘.{(⍺-1)↓⍵↑t}⍨⍳⍴t←⍵}
   f 0 0 0 0 0 1 0 1 1 1 1 1
2

Probabilmente questo può essere giocato un bel po ', specialmente la parte centrale, dove viene controllata la condizione della fase.

Spiegazione

Per prima cosa raccolgo le sottostringhe del vettore di input in una matrice, dove l'angolo superiore sinistro contiene l'intero input, usando ⌽∘.{(⍺-1)↓⍵↑t}⍨⍳⍴t←⍵. Per l'input 0 0 0 0 0 1 0, questa matrice è

┌───────────────┬─────────────┬───────────┬─────────┬───────┬─────┬───┬─┐
│1 0 0 0 0 0 1 0│1 0 0 0 0 0 1│1 0 0 0 0 0│1 0 0 0 0│1 0 0 0│1 0 0│1 0│1│
├───────────────┼─────────────┼───────────┼─────────┼───────┼─────┼───┼─┤
│0 0 0 0 0 1 0  │0 0 0 0 0 1  │0 0 0 0 0  │0 0 0 0  │0 0 0  │0 0  │0  │ │
├───────────────┼─────────────┼───────────┼─────────┼───────┼─────┼───┼─┤
│0 0 0 0 1 0    │0 0 0 0 1    │0 0 0 0    │0 0 0    │0 0    │0    │   │ │
├───────────────┼─────────────┼───────────┼─────────┼───────┼─────┼───┼─┤
│0 0 0 1 0      │0 0 0 1      │0 0 0      │0 0      │0      │     │   │ │
├───────────────┼─────────────┼───────────┼─────────┼───────┼─────┼───┼─┤
│0 0 1 0        │0 0 1        │0 0        │0        │       │     │   │ │
├───────────────┼─────────────┼───────────┼─────────┼───────┼─────┼───┼─┤
│0 1 0          │0 1          │0          │         │       │     │   │ │
├───────────────┼─────────────┼───────────┼─────────┼───────┼─────┼───┼─┤
│1 0            │1            │           │         │       │     │   │ │
├───────────────┼─────────────┼───────────┼─────────┼───────┼─────┼───┼─┤
│0              │             │           │         │       │     │   │ │
└───────────────┴─────────────┴───────────┴─────────┴───────┴─────┴───┴─┘

Quindi mappa la condizione di essere una fase su di essa, risultando nella matrice 0-1

0 0 0 0 0 0 0 0
1 0 1 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0

Per ottenere il numero di fasi massime, inondo le 1righe a destra e in basso usando ∨⍀∨\,

0 0 0 0 0 0 0 0
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1

raccogliere le righe univoche con ∪↓,

┌───────────────┬───────────────┐
│0 0 0 0 0 0 0 0│1 1 1 1 1 1 1 1│
└───────────────┴───────────────┘

e conta quelli che ne contengono almeno uno 1usando +/∨/¨.

* Esiste una codifica standard a 1 byte per APL.


Beh, è ​​difficile spiegare cosa sto chiedendo. Se avessi una spiegazione migliore del codice, allora potrei riformulare. Per ora cancellerò il mio commento.
Ottimizzatore

@Optimizer ho ampliato la spiegazione.
Zgarb,

1

Clojure, 302

(defn p[v l](if(or(<(count v)5)(= 0 l))nil(if((fn[v](let[f(first v)c(apply + v)o(count v)r(/ c o)t(+ f f r)](and(= f(last v))(or(> t 2.85)(< t 0.15)))))v)0(let[r(p(vec(drop-last v))(dec l))](if r(+ r 1)r)))))(defn s[v l c](if(empty? v)c(let[n(p v l)](if n(s(vec(rest v))n(inc c))(s(vec(rest v))l c)))))

e la versione leggermente non golfata

(defn is-phase [vector]
  (let [f (first vector)
        c (apply + vector)
        o (count vector)
        r (/ c o)
        t (+ f f r)]
    (and (= f (last vector))
         (or (> t 2.85) (< t 0.15)))))
(defn phase-index [vector last]
  (if (or (<(count vector)5)(= 0 last)) nil
    (if (is-phase vector) 0
      (let [r (phase-index (vec(drop-last vector)) (dec last))]
        (if r (+ r 1) r)))))
(defn phase-count [vector last count]
  (if (empty? vector) count
    (let [n (phase-index vector last)]
         (if n (phase-count (vec(rest vector)) n (inc count))
             (phase-count (vec(rest vector)) last count)))))

richiamabili in questo modo: (s [0 1 0 1 0] 10 0). Richiede alcuni argomenti extra, ma potrei sbarazzarmi di quelli con altri 20 caratteri.


0

JavaScript (ES6) 141

L'algoritmo di @ grc portato su
Input JavaScript può essere una stringa o un array

F=b=>
  (l=>{
    for(c=e=i=0;i<l;++i)
      for(j=l;j>i+4&j>e;--j)
        (k=0,[for(d of b.slice(i,j))k+=d==b[i]],k<(j-i)*.85)|b[i]-b[j-1]||(++c,e=j)
  })(b.length)|c

Test nella console FireFox / FireBug

;['01010', '00000', '0000101111',
'000001011111', '100000000000010',
'0000010000010000010', '00000100000100000100',
'010100101010001111010011000110',
'111110000011111001000000001101',
'011000000000001011111110100000'].forEach(t => console.log(t,F(t)))

Produzione

01010 0
00000 1
0000101111 0
000001011111 2
100000000000010 1
0000010000010000010 2
00000100000100000100 1
010100101010001111010011000110 0
111110000011111001000000001101 4
011000000000001011111110100000 5

0

CJam, 110 103 byte

Pretttttty long. Si può giocare molto a golf.

q~_,,\f>{_,),5>\f<{:X)\0==X1b_X,.85*<!\.15X,*>!X0=!*\X0=*+&},:,W>U):U+}%{,(},_{{_W=IW=>\1bI1b>!&!},}fI,

L'input è come

[0 1 1 0 0 0 0 0 0 0 0 0 0 0 1 0 1 1 1 1 1 1 1 0 1 0 0 0 0 0]

L'output è il numero di fasi.

Provalo online qui


0

JavaScript (ECMAScript 6), 148 139 byte

f=(s,l=0,e=0,p=0)=>{for(n=s.length,o=[j=0,y=0],i=l;i<n;++j>4&x==s[l]&i>e&c>=.85‌​*j&&(e=i,y=1))c=++o[x=s[i++]];return l-n?f(s,l+1,e,p+y):p}

Richiama attraverso l'array e avvia l'iterazione all'ultimo indice di ricorsione. L'argomento può essere una matrice o una stringa.

f('011000000000001011111110100000'); //5

1
Alcuni trucchi per il golf: -11. f=(s,l=0,e=0,p=0)=>{for(n=s.length,o=[j=0,y=0],i=l;i<n;++j>4&x==s[l]&i>e&c>=.85*j&&(e=i,y=1))c=++o[x=s[i++]];return l-n?f(s,l+1,e,p+y):p}
edc65,

0

Wolfram - 131

{x_, X___}⊕{Y__, x_, y___}/;MemberQ[t={x, X, Y, x}, 1-x] && t~Count~x > .85 Length@t := 
  1 + {X, Y, x}⊕{y} 
{_, X___}⊕y_ := {X}⊕y
{}⊕{y_, Y__} := {y}⊕{Y}
_⊕_ := 0

Esempio

{}⊕{1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0}
> 3
{}⊕{0,1,1,0,0,0,0,0,0,0,0,0,0,0,1,0,1,1,1,1,1,1,1,0,1,0,0,0,0,0}
> 5

0

Java: 771 byte

import java.util.*;public class A{static int[]a;static class b{int c,d,e,f,g,h;b(int i,int j){this.c=i;this.d=j;this.h=j-i+1;this.e=k();this.f=this.h-this.e;this.g=e>f?1:0;}
boolean l(b n){return this.c>=n.c&&this.d<=n.d;}
int k(){int o=0;for(int i=c;i<=d;i++){if(a[i]==1){o++;}}
return o;}
public boolean equals(Object o){b x=(b)o;return x.c==this.c&&x.d==this.d;}
float p(){if(g==0){return(float)f/h;}else{return(float)e/h;}}
boolean q(){float r=p();return a[c]==a[d]&&a[d]==g&&r>=0.85F;}}
static int s(int[]t){a=t;List<b>u=new ArrayList<>();for(int v=0;v<t.length-4;v++){int x=v+4;while(x<t.length){b y=new b(v,x);if(y.q()){u.add(y);}
x++;}}
List<b>a=new ArrayList<>();for(b c:u){for(b d:u){if(!c.equals(d)&&c.l(d)){a.add(c);break;}}}
u.removeAll(a);return u.size();}}

eseguito chiamando il metodo s (int [] input)

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.