Маскируйте IP-адрес и передавайте его

12

Фон

Вдохновлен этим вопросом Unix.SE (и, конечно, моим собственным ответом ).

Когда для интерфейса указывается IP-адрес, он часто задается в этой десятичной форме:

a.b.c.d e.f.g.h

где a.b.c.dфактический адрес и e.f.g.hмаска сети.

Маска сети, представленная в двоичном виде, представляет собой набор 1битов, за которыми следует набор 0битов. Когда сетевая маска побитово И сравнивается с данным IP-адресом, результатом будет сетевая часть адреса или просто сетевой адрес . Это будет запрограммировано в таблице маршрутизации хоста, чтобы хост знал, отправлять что-либо, предназначенное для этой сети, через этот интерфейс.

Широковещательный адрес для сети получается путем взятия сетевого адреса (сверху) и установки всех битов хоста в 1. Широковещательный адрес используется для отправки на все адреса в данной сети.

Вызов

Если задан десятичный пунктирный IP-адрес и действительная маска сети в качестве входных данных, укажите сетевой адрес и широковещательный адрес в качестве выходных данных, также в десятичном формате с точками.

  • Входные данные должны быть адресом и маской в ​​виде двух строк в точечно-десятичном формате. Вы можете передать это как 2 отдельные строки, как список или массив из 2 строковых элементов или одну строку с адресом и маской, разделенными некоторым разумным разделителем.
  • Формат вывода подчиняется тем же ограничениям, что и формат ввода.

Примеры

Input                              Output

192.168.0.1 255.255.255.0          192.168.0.0 192.168.0.255
192.168.0.0 255.255.255.0          192.168.0.0 192.168.0.255
192.168.0.255 255.255.255.0        192.168.0.0 192.168.0.255
100.200.100.200 255.255.255.255    100.200.100.200 100.200.100.200
1.2.3.4 0.0.0.0                    0.0.0.0 255.255.255.255
10.25.30.40 255.252.0.0            10.24.0.0 10.27.255.255
Цифровая травма
источник
2
Будет ли маска сети иметь только 255 и 0?
xnor
1
@xnor Последний пример содержит 252в себе.
user81655 25.12.15
2
Не должен ли быть последний вывод 10.24.0.0 10.27.255.255?
PurkkaKoodari
2
@ Pietu1998 нет, 255.252.0.0 - допустимая маска. В двоичном виде это 11111111.11111100.00000000.00000000
Цифровая травма
2
@ Pietu1998 Ах да, извините, это исправлено.
Цифровая травма

Ответы:

5

JavaScript (ES6), 92 байта

(a,m)=>a.split`.`.map((n,i)=>(v=m[i],m[i]=n&v|v^255,n&v),m=m.split`.`).join`.`+" "+m.join`.`

объяснение

(a,m)=>
  a.split`.`
  .map((n,i)=>(
      v=m[i],
      m[i]=n&v|v^255,
      n&v
    ),
    m=m.split`.`
  ).join`.`
  +" "+m.join`.`

Тестовое задание

user81655
источник
4

MATL , 47 байт

Этот ответ использует текущую версию (4.0.0) языка.

'%i.%i.%i.%i't32whh2:"j'\d+'XXU]tbZ&tb255Z~+hYD

пример

>> matl
 > '%i.%i.%i.%i't32whh2:"j'\d+'XXU]tbZ&tb255Z~+hYD
 > 
> 192.168.0.1
> 255.255.255.0
192.168.0.0 192.168.0.255

объяснение

'%i.%i.%i.%i't32whh      % format string: '%i.%i.%i.%i %i.%i.%i.%i'
2:"                      % for loop: do this twice
    j'\d+'XXU            % input string and parse into 4-vector with the numbers
]                        % end
tbZ&                     % compute network address
tb255Z~+                 % compute broadcast address
hYD                      % concatenate into 8-vector and apply format string
Луис Мендо
источник
0

PHP, 126 байт

С вводом в $ n:

preg_filter(~Ð×£ÔÖÐ,~Û¤¢Â×ÛÎÖÑ×ÛÔÔÁÌÀ×ÛÑÂ×ÛÂÛÁÊÀÝÑÝÅÝÝÖÑ×Û¤ÛÒÊ¢ÙÛÎÖÖÑ×ÛÑÂÛÑ×Û¤ÛÒÊ¢ÍÊÊÙÛÎÖÖÅÝÝÖ,$n);echo"$c $b";

HexDump:

0000000: 7072 6567 5f66 696c 7465 7228 7ed0 d7a3  preg_filter(~...
0000010: 9bd4 d6d0 9a2c 7edb 9ea4 a2c2 d7db ced6  .....,~.........
0000020: d1d7 db96 d4d4 c1cc c0d7 db9c d1c2 d7db  ................
0000030: 8bc2 db96 c1ca c0dd d1dd c5dd ddd6 d1d7  ................
0000040: db9e a4db 96d2 caa2 d9db ced6 d6d1 d7db  ................
0000050: 9dd1 c2db 8bd1 d7db 9ea4 db96 d2ca a283  ................
0000060: cdca cad9 81db ced6 d6c5 dddd d62c 246e  .............,$n
0000070: 293b 6563 686f 2224 6320 2462 223b       );echo"$c $b";

И более читаемая версия:

preg_filter( /* PCRE regex on input */
    '/(\d+)/e', /* match all digits, execute the code for each one */
    '$a[]=($1) /* push the matched value to the array $a */
        .($i++>3 /* if we're at the 5th or higher digit */
            ?($c.=($t=$i>5?".":"").($a[$i-5]&$1)) /* append to $c bitwise AND-ed number */
                .($b.=$t.($a[$i-5]|255&~$1)) /* append to $b the broadcast address */
            :"")',
    $n);
echo"$c $b"; /* output $c and $b */

preg_filterпри использовании eфлага требуется один оператор в шаблоне замены , поэтому я «добавляю» результат вычислений к 5-му и более высоким значениям $ a, потому что они никогда не используются повторно.

Аурел Белый
источник
0

Perl, 90 85 байт

включает в себя +6 за -pF/\D/

for(0..3){push@a,$F[$_]&1*($y=$F[$_+4]);push@b,$F[$_]|~$y&255}$"='.';$_="@a @b"

Использование:

echo "192.168.0.1 255.255.255.0" | perl -pF/\\D/ file.pl

Более читабельно:

for(0..3) {
    push @a, $F[$_] & 1*($y=$F[$_+4]);  # calc/add network address 'byte'
    push @b, $F[$_] | ~$y & 255         # calc/add broadcast address 'byte'
}
$"='.';                                 # set $LIST_SEPARATOR
$_="@a @b"                              # set output to network address and broadcast

-F/\D/Разбивает входной сигнал на нецифровые и сохраняет его в @F.

Кинни
источник
0

Фактор, 103 байта

[ [ ipv4-aton ] bi@ 2dup bitand -rot dup bit-count 32 - abs on-bits pick bitor 2nip [ ipv4-ntoa ] bi@ ]

Ницца.

Ungolfed:

: mask-and-broadcast ( ip mask -- netaddr broadcast )
  [ ipv4-aton ] bi@ 2dup bitand -rot dup bit-count 32 - abs on-bits pick bitor 2nip
  [ ipv4-ntoa ] bi@ ;
Кот
источник
0

PHP , 74 байта

<?=long2ip($i=ip2long($argv[1])&$m=ip2long($argv[2])),' ',long2ip($i|~$m);

В качестве отдельного ввода ввод осуществляется через командную строку:

$ php ip.php 192.168.0.1 255.255.255.0
192.168.0.0 192.168.0.255

Попробуйте онлайн!

Или, как функция, 80 байтов :

function($a,$b){return[long2ip($i=ip2long($a)&$m=ip2long($b)),long2ip($i|~$m)];}

Попробуйте онлайн!

Ungolfed

function ip( $a, $b ) {
    $i = ip2long( $a );          // string IP to 32 bit int
    $m = ip2long( $b );          // string netmask to 32 bit int
    $n = $i & $m;                // network is bitwise AND of IP and netmask
    $c = $i | ~$m;               // broadcast is bitwise OR of IP and inverse netmask
    return [ long2ip( $n ), long2ip( $c ) ];
}

PHP имеет хорошие (хотя и с длинными именами) встроенные функции для обработки точечной строки IPv4 в двоичную и обратно.

Выход

192.168.0.1 255.255.255.0   => 192.168.0.0 192.168.0.255
192.168.0.0 255.255.255.0   => 192.168.0.0 192.168.0.255
192.168.0.255 255.255.255.0 => 192.168.0.0 192.168.0.255
100.200.100.200 255.255.255.255 => 100.200.100.200 100.200.100.200
1.2.3.4 0.0.0.0 => 0.0.0.0 255.255.255.255
10.25.30.40 255.252.0.0 => 10.24.0.0 10.27.255.255
640 КБ
источник