栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

最小线段数以覆盖更大的线

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

最小线段数以覆盖更大的线

我设法编辑了您的解决方案,以为提供的链接上列出的所有数据集生成正确的输出。我的编辑如下:

  • segments
    数组从size 更改
    n+1
    为size
    n
    ,最后删除Integer.MAX_VALUE条目。
  • 改变
    segments[i] <= 0
    segments[i]-D <= 0
    对其中不存在条目<= 0的情况下,但有一个条目相交0。
  • 从改变for循环头
    for (int i = 0; i < L - 2 * D;)
    for (int i = 0; i < L - D;)
  • getNextSegment
    方法中添加了边界检查。

作为参考,我得到的代码如下:

Arrays.sort(segments);int current = -1;for (int i = n-1; i >= 0; i--) {    if (segments[i]-D <= 0) {        current = i;        break;    }}if (current == -1) {   System.out.println("Case #" + k + ": impossible");   continue;}int count = 1;boolean poss = true;for (int i = segments[current]; i < L-D;) {    count++;    int next = getNextSegment(current);    if (next == current) {        poss = false;        break;    }    current = next;    i = segments[current];}if (!poss)    System.out.println("Case #" + k + ": impossible");else    System.out.println("Case #" + k + ": " + count);

编辑后的

getNextSegment
方法如下所示:

int getNextSegment(int current) {    int i = current;    while(i < segments.length && segments[i] <= segments[current] + 2 * D)        i++;    return i - 1;}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/640734.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号