[Java] 201812-3 CIDR合并

本文探讨如何使用Java解决CIDR合并问题,并通过优化运行时间,从90分提升到100分,主要利用栈的数据结构进行优化。
摘要由CSDN通过智能技术生成
  • 从90分到100分,主要是运行超时的问题,这个我主要使用栈来优化
  • 样例输入1
2
1
2
  • 样例输出1
1.0.0.0/8
2.0.0.0/8
  • 样例输入2
2
10/9
10.128/9
  • 样例输出2
10.0.0.0/8
  • 样例输入3
2
0/1
128/1
  • 样例输出3
0.0.0.0/0
import java.io.*;
import java.util.*;

class Prefix implements Comparable<Prefix> {
   
	private int len;
	// ip对应的32位整数值,需要使用long型保存
	private long val;

	public int getLen() {
   
		return len;
	}

	public int compareTo(Prefix that) {
   
		if (this.val == that.val) {
   
			return this.len - that.len;
		}
		if (this.val < that.val) {
   
			return -1;
		}
		else if (this.val == that.val) {
   
			return 0;
		}
		else {
   
			return 1;
		}
	}

	public Prefix(Prefix a) {
   
		this.val = a.val;
		this.len = a.len - 1;
	}

	public Prefix(String ip, int len) {
   
		this.val = 0;
		this.len = len;
		// 这里的split里面是正则表达式,需要注意
		String[] arr = ip.split("\\.");
		// System.out.println(Arrays.toString(arr));
		long base = 1;
		for (int i = 3; i 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值