题目描述
子网掩码计算方法
子网掩码是用来判断任意两台计算机的IP地址是否属于同一子网络的根据。
最为简单的理解就是两台计算机各自的IP地址与子网掩码进行AND运算后,如果得出的结果是相同的,则说明这两台计算机是处于同一个子网络上的,可以进行直接的通讯。就这么简单。
请看以下示例:
运算演示之一:aa
I P 地址 192.168.0.1
子网掩码 255.255.255.0
AND运算
转化为二进制进行运算:
I P 地址 11010000.10101000.00000000.00000001
子网掩码 11111111.11111111.11111111.00000000
AND运算
11010000.10101000.00000000.00000000
转化为十进制后为:
192.168.0.0
运算演示之二:
I P 地址 192.168.0.254
子网掩码 255.255.255.0
AND运算
转化为二进制进行运算:
I P 地址 11010000.10101000.00000000.11111110
子网掩码 11111111.11111111.11111111.00000000
AND运算
11010000.10101000.00000000.00000000
转化为十进制后为:
192.168.0.0
运算演示之三:
I P 地址 192.168.0.4
子网掩码 255.255.255.0
AND运算
转化为二进制进行运算:
I P 地址 11010000.10101000.00000000.00000100
子网掩码 11111111.11111111.11111111.00000000
AND运算
11010000.10101000.00000000.00000000
转化为十进制后为:
192.168.0.0
通过以上对三组计算机IP地址与子网掩码的AND运算后,我们可以看到它运算结果是一样的。均为192.168.0.0
所以计算机就会把这三台计算机视为是同一子网络。
输入
第一行是本机IP地址
第二行是子网掩码
第三行整数N,表示后面有N个IP地址
第1个IP地址
......
第N个IP地址
输出
计算并输出N个IP地址是否与本机在同一子网内。
对于在同一子网的输出"INNER"
对于在不同子网的输出“OUTER”
样例输入
192.168.0.1
255.255.255.0
3
192.168.0.2
192.168.0.254
192.168.1.2
样例输出
INNER
INNER
OUTER
#include<stdio.h> int main() { int a3,b3,c3,d3,a1,b1,c1,d1,a2,b2,c2,d2; int n,i,j,a4,b4,c4,d4,a5,b5,c5,d5; scanf("%d.%d.%d.%d",&a1,&b1,&c1,&d1); scanf("%d.%d.%d.%d",&a2,&b2,&c2,&d2); scanf("%d",&n); a3=a1&a2;b3=b1&b2;c3=c1&c2;d3=d1&d2; //printf("%d.%d.%d.%d",a3,b3,c3,d3); for(i=0;i<n;i++) { scanf("%d.%d.%d.%d",&a4,&b4,&c4,&d4); a5=a4&a2;b5=b4&b2;c5=c4&c2;d5=d4&d2; if(a5==a3&&b3==b5&&c3==c5&&d3==d5) printf("INNER\n"); else printf("OUTER\n"); } }
本文介绍子网掩码的基本概念及计算方法,并通过示例详细解释如何使用子网掩码判断两台计算机是否位于同一子网络。此外,还提供了一个C语言编写的程序示例,用于自动检测多个IP地址是否与指定主机处于同一子网。
1297

被折叠的 条评论
为什么被折叠?



