Маскируйте 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`.`

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


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
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.