Генератор діапазону IP


11

Завдання проста, з урахуванням двох IP-адрес aі bвиведення всіх адрес у межах цього діапазону.


Приклади

Приклад №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

Приклад №2 (TIO урізає це, використовуючи менший діапазон при тестуванні):

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

Вхід і вихід

  • a < b іншими словами:
    • Програматично визначено :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])
    • Визначено у словах: a завжди буде нижчим за b(тому вам доведеться збільшувати підмережу, щоб дістатися b).
    • Ні, вам не доведеться впоратися a == b(якщо так, кудо).
  • Вихід повинен бути в порядку від "найнижчого" до "найвищого" (див. Приклади).
  • Для цього завдання, дійсний синтаксис для IP є: \d{1-3}\.\d{1-3}\.\d{1-3}\.\d{1-3}.
  • Вам не доведеться обробляти введення не IP-адреси, якщо це несподіване введення, ви можете помилитися.
  • Вихід може бути у вигляді масиву або як розділений рядок (використовуючи будь-який символ пробілу).

Перемога


1
У вас "Опущений шаблон" між, наприклад, 123.0.200.255та 123.0.201.0, але чи вони не є послідовними?
nmjcman101

@ nmjcman101 зробив це двічі, виправлено.
Magic Octopus Urn

Відповіді:


3

Піта, 22

mj\.jd256}FmivMcd\.256

Спробуйте в Інтернеті .

               cd\.       # split string by "."
             vM           # eval list (convert strings to integers)
            i      256    # convert list of base256 digits to integer
           m          Q   # map the above over implicit input list
         }F               # inclusive range
    jd256                 # convert to list of base256 digits
 j\.                      # join by "." 
m                         # map over inclusive range 

1
Це надихнуло зміни на Pyth, які в майбутньому повинні скоротити такий код. vMбуде застосовано за замовчуванням vпри застосуванні до списку.
isaacg

@isaacg круто - спасибі, я спробую запам'ятати це наступним разом.
Цифрова травма

3

Пакетна, 623 байти

@echo off
set s=%1.%2
call:c %s:.= %
exit/b
:c
if %1==%5 goto d
call:d %1 %2 %3 %4 %1 255 255 255
set/al=%1+1,u=%5-1
for /l %%i in (%l%,1,%u%)do call:d %%i 0 0 0 %%i 255 255 255
call:d %5 0 0 0 %5 %6 %7 %8
exit/b
:d
if %2==%6 goto e
call:e %1 %2 %3 %4 %1 %2 255 255
set/al=%2+1,u=%6-1
for /l %%j in (%l%,1,%u%)do call:e %1 %%j 0 0 %5 %%j 255 255
call:e %5 %6 0 0 %5 %6 %7 %8
exit/b
:e
if %3==%7 goto f
call:f %1 %2 %3 %4 %1 %2 %3 255
set/al=%3+1,u=%7-1
for /l %%k in (%l%,1,%u%)do call:e %1 %2 %%k 0 %5 %6 %%k 255
call:e %5 %6 %7 0 %5 %6 %7 %8
exit/b
:f
for /l %%l in (%4,1,%8)do echo %1.%2.%3.%%l

На жаль, 32-розрядна арифметика Batch не може надрукувати всі IP-адреси, тому мені доведеться розділити її на октети.


Видалення @echo offопції? Не те, що це робить величезну різницю.
Цифрова травма

@DigitalTrauma Я вважаю, що це не обов'язково, оскільки відлуння завжди йде до консолі, і тому це не є частиною STDOUT, але це дуже дратує, особливо на довгих сценаріях, таких як цей.
Ніл



2

Желе , 18 байт

ṣ”.V€ḅ⁹µ€r/b⁹j”.$€

Спробуйте в Інтернеті!

Виведення виглядає за допомогою грибів цифр і десяткових знаків, але зберігається внутрішньо як список рядків. Додайте а Yдо кінця (+1 байт), щоб з'єднати рядки за новими рядками.

Як це працює

ṣ”.V€ḅ⁹µ€r/b⁹j”.$€ - main link, input is a list of addresses which are strings
       µ€          - for each address string,
ṣ”.                  - split on periods
   V€                - eval each element in the list (convert strings to numbers)
     ḅ⁹              - transform from base 256 to integer (⁹ is 256)
         r/        - take the inclusive range
           b⁹      - convert each element in the range from integer to base 256
             j”.$€ - join each address with periods.

2

JavaScript (ES6), 104 байти

g=s=>s.replace(/(\d+)\.256/,(_,n)=>++n+'.0')
f=(a,b)=>a==b?a:a+`
`+f(g(g(g(g(a+'.256').slice(0,-2)))),b)

Це рішення замінює шаблон n .256 на n + 1 .0, і він називає себе рекурсивно, поки два параметри не будуть рівними.

Він додає ".256" до початкового входу, щоб отримати кульку. slice(0,-2)потім використовується для видалення останнього ".0".

Приклади:

g=s=>s.replace(/(\d+)\.256/,(_,n)=>++n+'.0')
f=(a,b)=>a==b?a:a+`
`+f(g(g(g(g(a+'.256').slice(0,-2)))),b)

console.log('192.168.0.1 ... 192.168.0.4');
console.log(f('192.168.0.1', '192.168.0.4'));

console.log('123.255.255.0 ... 124.0.3.0');
console.log(f('123.255.255.0', '124.0.3.0'));

console.log('192.1.1.1 ... 192.1.1.1 ... kudos');
console.log(f('192.1.1.1', '192.1.1.1'));


1

Java (OpenJDK 8) ,339 314 282 байти

Гольф:

long f(String i)throws Exception{return java.nio.ByteBuffer.wrap(java.net.InetAddress.getByName(i).getAddress()).getInt()&(1L<<32)-1;}void g(String[] a)throws Exception{for(long l=f(a[0]),m=255;l<=f(a[1]);)System.out.println(((l>>24)&m)+"."+((l>>16)&m)+"."+((l>>8)&m)+"."+(l++&m));}

Безголівки:

long ipToLong(String ip) throws Exception {
    return java.nio.ByteBuffer.wrap(java.net.InetAddress.getByName(ip).getAddress()).getInt() & (1L << 32) - 1;
}

void printRange(String[] ips) throws Exception {
    for (long ip = ipToLong(ips[0]), m = 255; ip <= ipToLong(ips[1]);)
        System.out.println(((ip >> 24) & m) + "." + ((ip >> 16) & m) + "." + ((ip >> 8) & m) + "." + (ip++ & m));
}

Спробуйте в Інтернеті!

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.