A tarefa é simples, considerando dois endereços IP a
e produzindo b
todos os endereços dentro desse intervalo.
Exemplos
Exemplo 1:
f(a = 192.168.0.1, b = 192.168.0.4)
192.168.0.1
192.168.0.2
192.168.0.3
192.168.0.4
Exemplo # 2 (o TIO truncará isso, use um intervalo menor ao testar):
f (a = 123.0.200.0, b = 124.0.0.0)
123.0.200.0
123.0.200.1
... # Omitted pattern
123.0.200.255
123.0.201.0
... # Omitted pattern
123.0.201.255
... # Omitted pattern
123.0.255.255
123.1.0.0
... # Omitted pattern
123.255.255.255
124.0.0.0
Entrada e saída
a < b
em outras palavras:- Definido programaticamente :
a[0] < b[0] || (a[0] == b[0] && a[1] < b[1]) || (a[0:1] == b[0:1] && a[2] < b[2]) || (a[0:2] == b[0:2] && a[3] < b[3])
- Definido em palavras:
a
sempre será menor queb
(assim você terá que incrementar a sub-rede para alcançarb
). - Não, você não precisa lidar com isso
a == b
(se sim, parabéns).
- Definido programaticamente :
- A saída deve estar na ordem de "mais baixo" para "mais alto" (veja exemplos).
- Para este desafio, a sintaxe válida por um IP é:
\d{1-3}\.\d{1-3}\.\d{1-3}\.\d{1-3}
. - Você não precisa lidar com a entrada de endereços não IP, se for uma entrada inesperada, poderá ocorrer um erro.
- A saída pode ser como uma matriz ou como uma sequência delimitada (usando qualquer caractere de espaço em branco).
Ganhando
- Isso é código-golfe , vitórias mais baixas na contagem de bytes.
123.0.200.255
e123.0.201.0
, mas eles não são sequenciais?