网络

教育改变生活

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1053|回复: 0
打印 上一主题 下一主题

Java编程-识别有效IP和编码并进行分类

[复制链接]

97

主题

98

帖子

447

积分

版主

Rank: 7Rank: 7Rank: 7

积分
447
跳转到指定楼层
楼主
发表于 2020-10-15 22:18:38 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
题目描述:
请解析IP地址和对应的掩码,进行分类识别。要求按照A/B/C/D/E类地址归类,不合法的地址和掩码单独归类。

所有的IP地址划分为 A,B,C,D,E五类

A类地址1.0.0.0~126.255.255.255;

B类地址128.0.0.0~191.255.255.255;

C类地址192.0.0.0~223.255.255.255;

D类地址224.0.0.0~239.255.255.255;

E类地址240.0.0.0~255.255.255.255


私网IP范围是:

10.0.0.0~10.255.255.255

172.16.0.0~172.31.255.255

192.168.0.0~192.168.255.255

子网掩码为二进制下前面是连续的1,然后全是0。(例如:255.255.255.32就是一个非法的掩码)
注意二进制下全是1或者全是0均为非法

注意:
1. 类似于【0.*.*.*】和【127.*.*.*】的IP地址不属于上述输入的任意一类,也不属于不合法ip地址,计数时可以忽略
2. 私有IP地址和A,B,C,D,E类地址是不冲突的。
输入描述:多行字符串。每行一个IP地址和掩码,用~隔开。
输出描述:统计A、B、C、D、E、错误IP地址或错误掩码、私有IP的个数,之间以空格隔开。

示例1
输入:
10.70.44.68~255.254.255.0
1.0.0.1~255.0.0.0
192.168.0.2~255.255.255.0
19..0.~255.255.255.0
输出:
1 0 1 0 0 2 1
实现代码:
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Main{
        public static void main(String[] args) throws IOException {
            BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
           
            int a = 0, b = 0, c = 0, d = 0, e = 0;
            int err = 0;
            int pri = 0;
            String str;
            String[] ip_mask;
            String[] ip;
            int i;
           
            while ((str = br.readLine()) != null) {
                ip_mask = str.split("~");
                ip = ip_mask[0].split("\\.");
                // count error mask
                if (checkMask(ip_mask[1])) { // mask correct
                    // count ip
                    if (checkIP(ip)) {
                        i = Integer.parseInt(ip[0]);
                        if (i >= 1 && i <= 126) { // A
                            a++;
                            if (i == 10) {
                                pri++;
                            }
                        } else if (i >= 128 && i <= 191) { // B
                            b++;
                            if (i == 172 && Integer.parseInt(ip[1]) >= 16 && Integer.parseInt(ip[1]) <= 31) {
                                pri++;
                            }
                        } else if (i >= 192 && i <= 223) { // C
                            c++;
                            if (i == 192 && Integer.parseInt(ip[1]) == 168) {
                                pri++;
                            }
                        } else if (i >= 224 && i <= 239) { // D
                            d++;
                        } else if (i >= 240 && i <= 255) { // E
                            e++;
                        }
                    } else {
                        err++;
                    }
                } else {
                    err++;
                }
            }
           
            // output
            System.out.println(a + " " + b + " " + c + " " + d + " " + e + " " + err + " " + pri);
        }
           
        private static boolean checkMask(String mask) {
            // check mask
            String[] mask_arr = mask.split("\\.");
            if (mask_arr[0].equals("255")) {
                if (mask_arr[1].equals("255")) {
                    if (mask_arr[2].equals("255")) {
                        return mask_arr[3].equals("254") || mask_arr[3].equals("252") || mask_arr[3].equals("248") ||
                                mask_arr[3].equals("240") || mask_arr[3].equals("224") || mask_arr[3].equals("192") ||
                                mask_arr[3].equals("128") || mask_arr[3].equals("0");
                    } else if (mask_arr[2].equals("254") || mask_arr[2].equals("252") || mask_arr[2].equals("248") ||
                            mask_arr[2].equals("240") || mask_arr[2].equals("224") || mask_arr[2].equals("192") ||
                            mask_arr[2].equals("128") || mask_arr[2].equals("0")) {
                        return mask_arr[3].equals("0");
                    } else
                        return false;
                } else if (mask_arr[1].equals("254") || mask_arr[1].equals("252") || mask_arr[1].equals("248") ||
                        mask_arr[1].equals("240") || mask_arr[1].equals("224") || mask_arr[1].equals("192") ||
                        mask_arr[1].equals("128") || mask_arr[1].equals("0")) {
                    return mask_arr[2].equals("0") && mask_arr[3].equals("0");
                } else {
                    return false;
                }
            } else if (mask_arr[0].equals("254") || mask_arr[0].equals("252") || mask_arr[0].equals("248") ||
                    mask_arr[0].equals("240") || mask_arr[0].equals("224") || mask_arr[0].equals("192") ||
                    mask_arr[0].equals("128") || mask_arr[0].equals("0")) {
                return mask_arr[1].equals("0") && mask_arr[2].equals("0") && mask_arr[3].equals("0");
            } else {
                return false;
            }
        }
           
        private static boolean checkIP(String[] ip) {
            return ip.length == 4 && !ip[0].equals("") && !ip[1].equals("") && !ip[2].equals("") && !ip[3].equals("");
        }
    }
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

WEB前端

QQ|手机版|小黑屋|金桨网|助学堂  咨询请联系站长。

GMT+8, 2024-12-22 01:02 , Processed in 0.033966 second(s), 21 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表