HJ18 识别有效的IP地址和掩码并进行分类统计 java实现

描述

请解析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地址和掩码,用~隔开。

请参考帖子https://www.nowcoder.com/discuss/276处理循环输入的问题。

输出描述:

统计A、B、C、D、E、错误IP地址或错误掩码、私有IP的个数,之间以空格隔开。

代码:

输入描述:

java 复制代码
import java.util.ArrayList;
import java.util.Iterator;
import java.util.Scanner;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {

    private static int NumberA;
    private static int NumberB = 0;
    private static int NumberC = 0;
    private static int NumberD = 0;
    private static int NumberE = 0;
    private static int NumberError = 0;
    private static int NumberPrivate = 0;


    public static void main(String[] args) {

        Scanner scanner = new Scanner(System.in);
        ArrayList<String> lists = new ArrayList<>();
        while (scanner.hasNextLine()) {
            String str = scanner.nextLine();
            lists.add(str);

        }

        dealIpAndMask(lists);

        printValue();


    }

    public static void dealIpAndMask(ArrayList<String> lists) {

        Iterator<String> iterator = lists.iterator();

        while (iterator.hasNext()) {

            String ipAndMask = iterator.next();
            String[] split = ipAndMask.split("~");

            if (!isMask(split[1]) || !isCorrcetIp(split[0])) {


                String ipFirst = null;
                ipFirst = split[0].split("\\.")[0];
                if (ipFirst.equals("0") || ipFirst.equals("127")) {

                } else {
                    NumberError++;
                }
//                System.out.println("ipFirst: "+ipFirst);
//                System.out.println(ipFirst+"  "+NumberError);


            } else {
                countIpType(split[0]);

            }


        }

    }

    public static void countIpType(String ip) {

        if (!isCorrcetIp(ip)) {
            return;
        }

        String[] split = ip.split("\\.");
        int ipFirstNum = Integer.parseInt(split[0]);
        int ipSecondNum = Integer.parseInt(split[1]);
        int ipThirdNum = Integer.parseInt(split[2]);

        //A类地址从1.0.0.0到126.255.255.255;
        if (ipFirstNum >= 1 && ipFirstNum <= 126) NumberA++;
        //B类地址从128.0.0.0到191.255.255.255;
        else if (ipFirstNum >= 128 && ipFirstNum <= 191) NumberB++;
        //C类地址从192.0.0.0到223.255.255.255;
        else if (ipFirstNum >= 192 && ipFirstNum <= 223) NumberC++;
        //D类地址从224.0.0.0到239.255.255.255;
        else if (ipFirstNum >= 224 && ipFirstNum <= 239) NumberD++;
        //E类地址从240.0.0.0到255.255.255.255
        else if (ipFirstNum >= 240 && ipFirstNum <= 255) NumberE++;


        //私网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
        if (ipFirstNum == 10) NumberPrivate++;
        else if (ipFirstNum == 172 && ipSecondNum >= 16 &&
                 ipSecondNum <= 31) NumberPrivate++;
        else if (ipFirstNum == 192 && ipSecondNum == 168) NumberPrivate++;


    }

    public static boolean isMask(String string) {

        String[] split = string.split("\\.");


        //1、mask要有四个段
        if (split.length!=4) return false;
        String mask = "";
        for (String str : split) {

            int parseInt = Integer.parseInt(str);
            //2、mask的值范围在0~255
            if (parseInt>255||parseInt<0) return false;
            if (str.length()==0) return false;
            int num = Integer.parseInt(str);
            String toBinaryString = Integer.toBinaryString(num);

            //3、很特殊的一个条件:mask每个段的值转换为二进制,从左到右依次为1,
            // 不能跳跃着来。例如可以为254,但是不能为127。如果段里面包含1,那么第八位一定为1,且转换为字符串长度一定为8
            if (toBinaryString.contains("1")){
                if (toBinaryString.length()!=8){
                    return false;
                }
            }

            mask += toBinaryString;

        }


        
        if (mask.contains("01")) return false;

        if (!mask.contains("1")) return false;//全是0

        if (!mask.contains("0")) return false;//全是1


        return true;
    }


    public static boolean isCorrcetIp(String ip) {

        String[] split = ip.split("\\.");
        if (split.length != 4) {
            return false;
        }

        if (split.length == 0) return false;

        for (String string : split) {
            if (string == null || string.length() == 0) {
                return false;
            }

            for (int i = 0; i < string.length(); i++) {
                if (string.charAt(i) < '0' || string.charAt(i) > '9') {
                    return false;
                }
            }

            int ipNumber = Integer.parseInt(string);
            if (ipNumber > 255 || ipNumber < 0) {
                return false;
            }


        }

        return true;
    }

    public static void printValue() {
        System.out.println(NumberA + " " + NumberB + " " + NumberC + " " + NumberD + " "
                           + NumberE + " " + NumberError + " " + NumberPrivate );
    }

}
相关推荐
爱读源码的大都督11 分钟前
为什么有了HTTP,还需要gPRC?
java·后端·架构
Lucky_Turtle30 分钟前
【Java Xml】Apache Commons Digester3解析
xml·java·apache
聪明的笨猪猪1 小时前
Java Redis “缓存设计”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
FIavor.1 小时前
我发送给Apifox是http://localhost:9002/goods/getByUserName?name=张三 为什么会是500哪里错了?
java·服务器·网络协议·http
ID_180079054731 小时前
京东获取整站实时商品详情数据|商品标题|数据分析提取教程
java·开发语言
微露清风1 小时前
系统性学习C++-第五讲-内存管理
java·c++·学习
计算机毕业设计木哥2 小时前
计算机毕业设计选题推荐:基于SpringBoot和Vue的快递物流仓库管理系统【源码+文档+调试】
java·vue.js·spring boot·后端·课程设计
235162 小时前
【LeetCode】146. LRU 缓存
java·后端·算法·leetcode·链表·缓存·职场和发展
聪明的笨猪猪2 小时前
Java Redis “运维”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
FIavor.2 小时前
怎么办这是Apifox里执行http://localhost:9002/goods/getByUserName?name=“张三“为什么我改了还是500?
java·网络·网络协议·http