📣 独立日限时特惠: VIP通行证立减$68
楼主: 匿名
跳转到指定楼层
上一主题 下一主题
收起左侧

字节北美电面两题

🔗
儒雅随和 2020-12-6 02:56:48 | 只看该作者
全局:
请问第一题怎么做
回复

使用道具 举报

🔗
woshilxd912 2020-12-6 06:35:33 | 只看该作者
全局:
自己写了个第二题题解,不过用到了排序,中间该融合的融合,肯定至少是nlogn了,不知道是不是比nlogn还要久。
  1. public class Solution {

  2.     public static void main(String[] args) {
  3.         List<String> subnetsStrs = new ArrayList<>();
  4.         subnetsStrs.add("11.23.1.0/24");
  5.         subnetsStrs.add("11.23.0.0/24");
  6.         subnetsStrs.add("11.23.7.0/24");
  7.         subnetsStrs.add("11.23.6.0/24");
  8.         subnetsStrs.add("11.23.3.0/24");
  9.         subnetsStrs.add("11.23.2.0/24");
  10.         List<String> res = mergeSubnets(subnetsStrs);
  11.         System.out.println(res.toString());
  12.     }

  13.     static List<String> mergeSubnets(List<String> subnetStrs) {
  14.         PriorityQueue<Subnet> subnets = new PriorityQueue<>(
  15.             (a, b) -> a.maskLen == b.maskLen ? Long.compare(a.mask, b.mask)
  16.                 : Integer.compare(b.maskLen, a.maskLen));
  17.         for (String subnet : subnetStrs) {
  18.             subnets.offer(parseSubnet(subnet));
  19.         }
  20.         List<String> res = new ArrayList<>();
  21.         while (!subnets.isEmpty()) {
  22.             Subnet subnet = subnets.poll();
  23.             if (!subnets.isEmpty() && subnets.peek().maskLen == subnet.maskLen
  24.                 && (subnet.mask ^ subnets.peek().mask) ==
  25.                 1L << (32 - subnet.maskLen)) {
  26.                 subnets.poll();
  27.                 subnets.offer(
  28.                     new Subnet(subnet.maskLen - 1, removeLastBit(subnet.mask, subnet.maskLen - 1)));
  29.             } else {
  30.                 res.add(subnet.toString());
  31.             }
  32.         }
  33.         return res;
  34.     }

  35.     static private long removeLastBit(long mask, long newMaskLen) {
  36.         long tmp = 0;
  37.         for (int i = 0; i < 32; ++i) {
  38.             tmp <<= 1;
  39.             if (i < newMaskLen) {
  40.                 ++tmp;
  41.             }
  42.         }
  43.         return mask & tmp;
  44.     }

  45.     static private Subnet parseSubnet(String subnet) {
  46.         String[] strs = subnet.split("/");
  47.         long mask = 0;
  48.         for (String num : strs[0].split("\\.")) {
  49.             mask = mask * 256 + Long.parseLong(num);
  50.         }
  51.         return new Subnet(Integer.parseInt(strs[1]), mask);
  52.     }

  53.     private static class Subnet {

  54.         int maskLen;
  55.         long mask;

  56.         public Subnet(int maskLen, long mask) {
  57.             this.maskLen = maskLen;
  58.             this.mask = mask;
  59.         }

  60.         @Override
  61.         public String toString() {
  62.             return String.valueOf(mask / (1 << 24)) + '.' + mask / (1 << 16) % 256 + '.'
  63.                 + mask / (1 << 8) % 256 + '.' + mask % 256 + '/' + maskLen;
  64.         }
  65.     }
  66. }
复制代码


回复

使用道具 举报

🔗
johnnywsd 2020-12-8 14:50:51 | 只看该作者
全局:
Follow up: solve by time complexity O(NlogN).


第一题中的N指代什么?
回复

使用道具 举报

🔗
treeguard 2020-12-25 19:08:52 | 只看该作者
全局:
woshilxd912 发表于 2020-12-6 06:35
自己写了个第二题题解,不过用到了排序,中间该融合的融合,肯定至少是nlogn了,不知道是不是比nlogn还要久 ...

感觉这个解法不对 如果subnet之间是包含关系呢?
回复

使用道具 举报

🔗
woshilxd912 2020-12-26 01:51:11 | 只看该作者
全局:
treeguard 发表于 2020-12-25 19:08
感觉这个解法不对 如果subnet之间是包含关系呢?

可以举个例子验证一下吗,我也不是很清楚
回复

使用道具 举报

🔗
BenoitCJTV 2020-12-26 01:57:51 | 只看该作者
本楼:
全局:
感谢分享
回复

使用道具 举报

🔗
treeguard 2020-12-26 05:20:55 | 只看该作者
全局:
woshilxd912 发表于 2020-12-26 01:51
可以举个例子验证一下吗,我也不是很清楚

比如说一个 是 1.1.1.0/24 和 1.1.0.0/22 那结果就是 1.1.0.0/22 感觉你的解法没有catch到?
回复

使用道具 举报

全局:
treeguard 发表于 2020-12-25 13:20:55
比如说一个 是 1.1.1.0/24 和 1.1.0.0/22 那结果就是 1.1.0.0/22 感觉你的解法没有catch到?
你这个例子也没法融合,输入是什么,输出就是什么,我的程序跑出来是什么样呢,电脑现在不在身边
回复

使用道具 举报

🔗
treeguard 2020-12-26 07:41:46 | 只看该作者
全局:
woshilxd912 发表于 2020-12-26 05:35
你这个例子也没法融合,输入是什么,输出就是什么,我的程序跑出来是什么样呢,电脑现在不在身边

1.1.0.0/22 已经包含了 1.1.1.0/24所能包含的所有IP地址了
回复

使用道具 举报

🔗
quanatm 2020-12-26 07:51:52 | 只看该作者
全局:
前两轮蠡口
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

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