Corrisponde al modello delle cifre?


23

Di recente ho fatto un test di matematica e ho notato che un certo numero nel test corrispondeva a uno schema interessante. Il numero ( 28384) corrisponde a una sequenza di cifre generica simile a questa

(n)(x)(n+1)(x)(n+2)(x)(n+3) etc...

dove ne xsono numeri interi a una cifra. La sequenza può iniziare con o xo ne terminare con xo n+y.

Il tuo compito è, dato un numero intero positivo a più cifre, emettere un valore di verità o falsità, a seconda che l'input corrisponda al modello. L'input avrà una lunghezza compresa tra 4 e 18 cifre. È possibile accettare input come rappresentazione di stringa dell'intero. L'input non inizierà con uno 0 ma può contenere o terminare con 0s.

n+y sarà sempre un numero a una cifra (quindi perché il limite di lunghezza è 18).

Casi test

Questi dovrebbero produrre un valore veritiero

182838485868788898
4344
85868
12223242526

E questi dovrebbero essere falsi

12345
6724013635
36842478324836
1222232425
5859510511

Come per tutti i golf di codice, vince il codice più corto! Buona fortuna e che le probabilità siano sempre a tuo favore!


Possiamo prendere l'input come una stringa?
Kritixi Lithos,

@KritixiLithos "È possibile accettare input come rappresentazione di stringa dell'intero."
Mr. Xcoder,

Sono entrambi xe ndiversi da zero per i numeri che rientrano nella regola?
Mr. Xcoder,

@ Mr.Xcoder il numero non può iniziare con 0 ma può contenere o terminare con 0s
caird coinheringaahing

Risposte:


8

Python 2 , 84 81 80 79 byte

-1 byte grazie a ovs

lambda x:g(x,1)|g(x,0)
g=lambda x,a:len(set(x[a::2]))==(x[a<1::2]in"123456789")

Provalo online!


Python 3 , 82 79 78 77 byte

lambda x:g(x,1)|g(x,0)
g=lambda x,a:len({*x[a::2]})==(x[a<1::2]in"123456789")

Provalo online!

Leggermente più breve in Python 3, ma non pensavo che meritasse una sua risposta.


Spiegazione

Impostiamo una funzione gche accetta string e un indice (1 o 0). gquindi restituisce se len(set(x[a::2])), ovvero il numero di cifre univoche in ogni altra posizione, è uguale (x[a==0::2]in"123456789")o meno, se le altre cifre sono o meno in ordine crescente. Se le cifre sono in ordine crescente, questo restituisce se sono tutte uguali, altrimenti chiederà se l'insieme è vuoto, cosa che non può essere, restituendo quindi sempre falso.


Come al solito, sono stato superato>> <
Mr. Xcoder il

x[a<1::2]in"123456789"può essere "0"<x[a<1::2]<":"(confrontando i caratteri confronta i codici di carattere)
CalculatorFeline

@CalculatorFeline Non credo sia vero. Questo controlla solo che la stringa inizia con un numero.
Wheat Wizard

Oh giusto, comunque funziona per singoli personaggi.
Calcolatrice

Ma hai davvero bisogno a<1? Sembra che possa essere giusto a.
Calcolatrice

4

Gelatina , 13 11 byte

Ds2ZI’M¦Ẏ¬Ạ

Provalo online!

Spiegazione:

Ds2ZI’M¦Ẏ¬Ạ Accepts an integer
D           Get individual digits
  2         2
 s          Split into chunks of specific length
   Z        Zip
    I       Take deltas
     ’      Decrement
      M     Take maximal indices
       ¦    Apply at specific indices
        Ẏ   Reduce dimensionality
         ¬  Vectorized NOT
          Ạ Check if all are truthy

2

05AB1E , 15 byte

TG9LNýN.øŒ})˜Iå

Provalo online!

Spiegazione

TG9LNýN.øŒ})˜Iå
TG        }     # For 1 to 9...
  9L             # Push [1 .. 9]
    Ný           # Join with current value 
      N.ø        # surround with current value
         Œ       # Push substrings
           )    # Wrap stack to array
            ˜   # Deep flatten the array
             I  # Push input
              å # Is the input in the array?
                # Implicit print

Dovrebbe funzionare (casi di test hanno funzionato) ma se trovi qualche difetto per favore fammi sapere.

14 byte se nessuna uscita è considerata falsa:

TG9LNýN.øŒIåi1

2

D, 117 byte

int f(string n){int o=n[0]!=n[2],x=n[o];foreach(i,c;n){if(i%2!=o&&i>1&&c!=n[i-2]+1||i%2==o&&c!=x)return 0;}return 1;}

Decisamente non ottimale, ma funziona benissimo

Provalo online!


2

Haskell, 108 113 97 95 byte

d(x:_:r)=x:d r
d r=r
c(x:n:r)=and$all(==x)(d r):zipWith(==)(d$n:r)[n..]
f s@(_:n:_)=c s||c(n:s)

Chiamata di esempio: f "182838485868788898"reseTrue

Versione non golfata con spiegazioni:

-- Take every other element from the string, starting with the first
d (x:_:r) = x : d r
d r       = r
c (x:n:r) = and $ all (== x) (d r)              -- Every other char is equal to the first
                : zipWith (==) (d $ n:r) [n..]  -- The remaining chars are a prefix of n(n+1)(n+2)...
f s@(_:n:_) = c s      -- The case where s already starts with x
           || c (n:s)  -- If not, prepend a dummy x and try again

2
Benvenuti in particolare al golf PPCG e Haskell! isPrefixOfnon è in Preludio, quindi devi includere import Data.Listnel tuo codice o utilizzare un'alternativa, ad es and(zipWith(==)(n:r)[n..]).
Laikoni,

@Laikoni: grazie per il suggerimento! Ho sostituito la funzione di conseguenza.
siracusa

1
Penso che x/=ypossa essere solo 1>0perché se non x/=yallora x==ye il primo caso lo cattura.
Calcolatrice

Inoltre non hai bisogno delle funzioni ausiliarie where, definitive ce dcome al di fuori di f. fpuò quindi essere abbreviato in f s@(_:n:_)=c s||c(n:s).
Laikoni,

1
Allora potresti essere interessato alla guida alle regole del golf in Haskell . Anche se non è una regola, puoi usare newline invece di ;. Ha lo stesso numero di byte ma migliora la leggibilità del codice.
Laikoni,

1

JavaScript (ES6), 66 63 60 byte

Accetta l'input come stringa.

s=>[...s].every((d,i)=>d-s[j^(k=i+j&1)]==k*i>>1,j=s[2]-s[0])

Casi test


1

C (gcc), 123 byte

#define X*s&&*s++-++n&&(r=0)
t,n,x,r;f(char*s){t=*s==s[2];for(r=1,n=s[t],x=s[!t],s+=2;*s;)t||X,*s&&*s++-x&&(r=0),t&&X;n=r;}

Provalo online!


1

Python 3 , 99 96 89 byte

  • 3 byte salvati: utilizzo della all()funzione
  • @WheatWizard ha salvato 7 byte: shorthanding & |e sostituisce la variabile extra conk<1
lambda x,g=lambda x,k:(x[k<1::2]in'123456789')&all(j==x[k]for j in x[k::2]):g(x,0)|g(x,1)

Provalo online!

Spiegazione:

Dapprima dividi la stringa in due elenchi: uno con gli indici dispari e l'altro con gli elementi pari. Le due liste A e B dovrebbero essere tali che:

  1. A contiene lo stesso numero e B contiene numeri consecutivi in ​​ordine crescente.

O esattamente il contrario

  1. B contiene lo stesso numero e A contiene numeri consecutivi in ​​ordine crescente.

Le condizioni consecutive sono verificate da: a in '123456789'

La condizione dello stesso numero è controllata da: all(i=a[x] for i in a)


1
puoi sostituire le istanze di icon k<1e rilasciare l' iargomento tutti insieme.
Mago del grano,

1
Puoi anche racchiudere il primo predicato in parentesi e usare &invece di and. Anche il tuo orpuò essere sostituito |.
Wheat Wizard

1
Vedo che questo alla fine converge verso la tua risposta ..: D
officialaimm,

1

PHP , 68 byte

for(;$v<10;)$s.=strstr(+$v.join(+$v,range(1,9)).+$v++,$argn);echo$s;

Provalo online!

Emette parte della stringa di ricerca a partire da e includendo la prima occorrenza dell'input alla fine della stringa di ricerca come valore di verità e niente per falsa

per 2 byte è possibile sostituire echo$s;con !!echo$s;per ottenere 1come valore di truthy

Trova la ricorrenza dell'input in una delle seguenti stringhe nell'array

Array
(
    [0] => 0102030405060708090
    [1] => 1112131415161718191
    [2] => 2122232425262728292
    [3] => 3132333435363738393
    [4] => 4142434445464748494
    [5] => 5152535455565758595
    [6] => 6162636465666768696
    [7] => 7172737475767778797
    [8] => 8182838485868788898
    [9] => 9192939495969798999
)

1

JavaScript (ES6), 54 byte

f=
s=>[...s].every((e,i)=>i<2|e-s[i-2]==(s[2]!=s[0])^i%2)
<input oninput=o.textContent=this.value[3]?f(this.value):``><pre id=o>

Accetta l'input come stringa.


1

MATL , 15 byte

2L&),duw]hSFTX=

Provalo online!

Con l'aiuto di @LuisMendo in chat. Si noti che, se anche l'output vuoto + errore viene considerato 'falso', il valore Xpuò essere lasciato fuori, portando il punteggio a 14 byte .

2L&)     % Split the input into odd and even-indexed elements
    ,   ] % Do twice (new feature since MATL v20.0), i.e., on both halves of the input
     d     % Pairwise differences of the array. Results in [0,0,...] for the 'constant' part,
            %  and [1,1,...] for the 'increasing' part.
      u      % Get unique elements. Results in [0] for the constant part, [1] for the increasing part.
       w      % Swap the stack to do the same for the other half of the input.
         hS    % Horizontal concatenation followed by sort. Results in [0,1] for the desired string.
           FTX= % Check if the result is indeed [0,1]. Implicit display.

0

Mathematica, 121 byte

(m[x_]:=Take[s=IntegerDigits@#,{x,Length@s,2}];w[b_,n_]:=Union@Differences@m@b=={1}&&Length@Union@m@n==1;w[1,2]||w[2,1])&

0

Pyth , 20 byte

ASm.+sMd.Tcz2&-GZ-H1

Produzione [] quando il numero corrisponde allo schema delle cifre, altrimenti.

Provalo online!

Spiegazioni (esempio con input 85868)

ASm.+sMd.Tcz2&-GZ-H1

          cz2           # Chop the input in pairs: ['85', '86', '8']
        .T              # Transpose, ignore absences: ['888', '56']
     sM                 # Convert to integers: [[8, 8, 8], [5, 6]]
  m.+  d                # Compute deltas: [[0, 0], [1]]
 S                      # Sort: [[0, 0], [1]]
A                       # Assign first list to G and second list to H
              -GZ       # Filter 0 on G (on absence): [0, 0] -> []
                 -H1    # Filter 1 on H (on absence): [1] -> []
             &          # Check both lists are empty (logical and): [] & [] -> []

0

Pyth, 17 byte

qU2Ssm{.+d.TcjQT2

Provalo qui

Stesso algoritmo della mia risposta Jelly.

Spiegazione:

qU2Ssm{.+d.TcjQT2 Accepts an integer
             jQT  Take digits of input
            c   2 Split in pairs
          .T      Transpose
     m            Map the following on each of the two resulting lists:
       .+d          Take deltas
      {             Deduplicate
    s             The list is now in [[a, b, ...], [A, B, ...]] format, convert it to [a, b, ..., A, B, ...]
   S              Sort
qU2               Check if equal to [0, 1]

0

Python 3 , 167 161 157 131 106 byte

-55 byte grazie ai suggerimenti di @ WheatWizard

def g(t):k,c,f,j=t[::2],t[1::2],'123456789',''.join;return(len({*k})and j(c)in f)or(len({*c})and j(k)in f)

Provalo online!


Può essere ulteriormente giocato a golf. Ho già modificato.
Mr. Xcoder,

Potresti aver visto questo trucco nella mia risposta ma set(c)è lo stesso di {*c}. (almeno in Python 3)
Wheat Wizard il

@WheatWizard thanks. Modifica
Mr. Xcoder il

3
[t[z]for z in range(0,len(t),2)]è anche solo un elenco di giunzioni. Puoi farlo semplicemente con t[::2]. Se non hai familiarità con questa sintassi, ti suggerisco di dare un'occhiata ai documenti, perché è piuttosto utile.
Wheat Wizard

@WheatWizard Wow, è davvero utile. Purtroppo, non posso modificare la risposta in questo momento. Lo farò appena posso. Grazie mille per il consiglio ...
Mr. Xcoder,

0

Java (OpenJDK 8) , 128 119 118 108 107 104 byte

s->{int i=3,a=s[2]-s[0],b=s[3]-s[1];for(;++i<s.length;)a+=b-(b=s[i]-s[i-2]==a?a:2);return(a|b)==1&a!=b;}

Provalo online!

Spiegazione:

s->{                             // lambda
  int i=3,                       //  iterating index
      a=s[2]-s[0],               //  diff of even-indexed characters
      b=s[3]-s[1];               //  diff of odd-indexed characters
  for(;++i<s.length;)            //  iterate
    a+=b-(b=                     //   swap a and b
        s[i]-s[i-2]==a?a:2       //    or set b to 2 if the diffs don't match
      ));                        //
  return (a|b)==1                //  return true if both a and b are in (0,1)
        &a!=b;                   //         but different
}

0

Retina , 47 byte

.
$*11;
(1+)(?<=\1;1+;\1)

^1+;1+

^;?(;1;)+;?$

Provalo online!

Emette 1 se corrisponde al modello, 0 in caso contrario

Spiegazione

.
$*11;

Converti ogni cifra da n a n + 1 in unario, separati da punti e virgola

(1+)(?<=\1;1+;\1)

(Traline newline) converte ogni cifra nella differenza tra se stessa e quella di 1 punto prima di essa

^1+;1+

(Trailing newline) rimuove le prime 2 cifre

^;?(;1;)+;?$

Conta il numero di corrispondenze di questo modello, che verifica la presenza di 0 e 1 alternati

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.