热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

计算多段时间的重叠

packagecom.lihong.DDPush.pms;importcom.lihong.DDPush.mybatis.Parser;importorg.junit.Test;impor
package com.lihong.DDPush.pms;

import com.lihong.DDPush.mybatis.Parser;
import org.junit.Test;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;

/**
* Created by lihong10 on 2017/9/28.
*/

public class TimeOverlapTest {

public static final String YYYY_MM_DD_HH_MM_SS = "yyyy-MM-dd HH:mm:ss";

@Test
public void test() {
String[] params = new String[] {
"2017-09-28 08:00:00",
"2017-09-28 10:00:00",
"2017-09-28 12:00:00",
"2017-09-28 15:00:00",
"2017-09-28 07:00:00",
"2017-09-28 18:00:00"
};

String[] params1 = new String[] {
"2017-09-28 08:00:00",
"2017-09-28 10:00:00",
"2017-09-28 12:00:00",
"2017-09-28 15:00:00"
};

String[] params2 = new String[] {
"2017-09-28 07:00:00",
"2017-09-28 18:00:00"
};

caculate(params, params1, params2);
}


@Test
public void test01() {
String[] params = new String[]{
"2017-09-28 08:00:00",
"2017-09-28 17:00:00",
"2017-09-28 09:00:00",
"2017-09-28 16:00:00"
};
String[] params1 = new String[]{
"2017-09-28 08:00:00",
"2017-09-28 17:00:00"
};

String[] params2 = new String[]{
"2017-09-28 09:00:00",
"2017-09-28 16:00:00"
};
caculate(params, params1, params2);
}


@Test
public void test02() {
String[] params = new String[]{
"2017-09-28 08:00:00",
"2017-09-28 10:00:00",
"2017-09-28 09:00:00",
"2017-09-28 12:00:00",
"2017-09-28 11:00:00",
"2017-09-28 13:00:00",
"2017-09-28 12:00:00",
"2017-09-28 15:00:00"
};

String[] params1 = new String[]{
"2017-09-28 08:00:00",
"2017-09-28 10:00:00",
"2017-09-28 09:00:00",
"2017-09-28 12:00:00",
"2017-09-28 11:00:00",
"2017-09-28 13:00:00"
};

String[] params2 = new String[]{
"2017-09-28 12:00:00",
"2017-09-28 15:00:00"
};

caculate(params, params1, params2);
}


@Test
public void test03() {
String[] params = new String[]{
"2017-09-28 08:00:00",
"2017-09-28 10:00:00",
"2017-09-28 09:00:00",
"2017-09-28 12:00:00",
"2017-09-28 11:00:00",
"2017-09-28 13:00:00",
"2017-09-28 12:00:00",
"2017-09-28 15:00:00",
"2017-09-28 07:00:00",
"2017-09-28 11:00:00"
};

String[] params1 = new String[]{
"2017-09-28 08:00:00",
"2017-09-28 10:00:00",
"2017-09-28 09:00:00",
"2017-09-28 12:00:00",
"2017-09-28 11:00:00",
"2017-09-28 13:00:00"
};

String[] params2 = new String[]{
"2017-09-28 12:00:00",
"2017-09-28 15:00:00",
"2017-09-28 07:00:00",
"2017-09-28 11:00:00"
};

caculate(params, params1, params2);
}


@Test
public void test04() {
String[] params = new String[]{
"2017-09-28 08:00:00",
"2017-09-28 10:00:00",
"2017-09-28 09:00:00",
"2017-09-28 12:00:00",
"2017-09-28 11:00:00",
"2017-09-28 13:00:00",
"2017-09-28 12:00:00",
"2017-09-28 15:00:00",
"2017-09-28 07:00:00",
"2017-09-28 11:00:00"
};

String[] params1 = new String[] {
"2017-09-28 08:00:00",
"2017-09-28 10:00:00",
"2017-09-28 09:00:00",
"2017-09-28 12:00:00",
"2017-09-28 11:00:00",
"2017-09-28 13:00:00"
};

String[] params2 = new String[]{
"2017-09-28 12:00:00",
"2017-09-28 15:00:00",
"2017-09-28 07:00:00",
"2017-09-28 11:00:00"
};

caculate(params, params1, params2);
}


/**
* @Author: lihong10
* @Description:
* @param
* @Date: 2017/9/30 14:34
*/

@Test
public void test05() {
String[] params = new String[] {
"2017-09-28 07:00:00",
"2017-09-28 10:00:00",
"2017-09-28 13:00:00",
"2017-09-28 18:00:00",
"2017-09-28 21:00:00",
"2017-09-28 23:00:00",
"2017-09-28 01:00:00",
"2017-09-28 23:40:00"
};

String[] params1 = new String[] {
"2017-09-28 07:00:00",
"2017-09-28 10:00:00",
"2017-09-28 13:00:00",
"2017-09-28 18:00:00",
"2017-09-28 21:00:00",
"2017-09-28 23:40:00"
};

String[] params2 = new String[]{
"2017-09-28 01:00:00",
"2017-09-28 23:40:00"
};

caculateNotInHoliday(params, params1, params2);
}



private void caculateNotInHoliday(String[] params, String[] authTimes, String[] parkTimes) {
List dates = getDateList(params);
removeRepeat(dates);
Collections.sort(dates);


List pairs = new ArrayList();

for (int i = 0, j = dates.size(); i if ((i + 2) <= j) {

System.out.println("i: " + i + ", j: " + (i + 1));
TimePair pair = new TimePair(dates.get(i), dates.get(i + 1));
pairs.add(pair);
pair.caculateOverLapWithAuth(getDateList(authTimes));
pair.caculateOverLapWithStay(getDateList(parkTimes));
System.out.println(pair);
System.out.println();
}
}


System.out.println("===============================================================================");
System.out.println(pairs);
System.out.println("===============================================================================");
List notInHolidayLi = new ArrayList<>();
for (int i = 0; i TimePair pair = pairs.get(i);
if (pair.notInHoliday()) {
notInHolidayLi.add(pair);
System.out.println(pair);
}
}

System.out.println("===============================================================================");
System.out.println(notInHolidayLi);
System.out.println("===============================================================================");
System.out.println(mergeContinous(notInHolidayLi));

}


private void caculate(String[] params, String[] authTimes, String[] parkTimes) {
List dates = getDateList(params);
removeRepeat(dates);
Collections.sort(dates);


List pairs = new ArrayList();

for (int i = 0, j = dates.size(); i if ((i + 2) <= j) {

System.out.println("i: " + i + ", j: " + (i + 1));
TimePair pair = new TimePair(dates.get(i), dates.get(i + 1));
pairs.add(pair);
pair.caculateOverLapWithAuth(getDateList(authTimes));
pair.caculateOverLapWithStay(getDateList(parkTimes));
System.out.println(pair);
System.out.println();
}
}


System.out.println("===============================================================================");
System.out.println(pairs);
System.out.println("===============================================================================");
List chargeTimes = new ArrayList<>();
for (int i = 0; i TimePair pair = pairs.get(i);
if (pair.needCharge()) {
chargeTimes.add(pair);
System.out.println(pair);
}
}


System.out.println("===============================================================================");
System.out.println("-------------------------------------------------------------------------------");
System.out.println(chargeTimes);
System.out.println("-------------------------------------------------------------------------------");
System.out.println(mergeContinous(chargeTimes));

}

public void removeRepeat(List dates) {

for (int i = 0; i <(dates.size() - 1); i++) {
for (int j = i + 1; j System.out.print("remove i: " + i);
System.out.print("remove j: " + j);
if (dates.get(i).getTime() == dates.get(j).getTime()) {
dates.remove(j);
}
}
}
}


public List mergeContinous(List pairs) {

if (pairs == null || pairs.size() == 0) {
return new ArrayList();
}

List li = new ArrayList();

if (pairs.size() == 1) {
Pair p = new Pair(pairs.get(0).getStartTime(), pairs.get(0).getEndTime());
li.add(p);
return li;
}

Date start = pairs.get(0).getStartTime();
Date end = pairs.get(0).getEndTime();
for (int i = 1; i TimePair tp = pairs.get(i);
if (tp.getStartTime().getTime() == end.getTime()) {
end = tp.getEndTime();
} else {
Pair pr = new Pair(start, end);
li.add(pr);

start = tp.getStartTime();
end = tp.getEndTime();
}
}

li.add(new Pair(start, end));

return li;
}


public static boolean isCollectionEmpty(Collection collection) {
if (collection == null || collection.isEmpty()) {
return true;
}
return false;
}


public static Date stringToDate(String strValue, String strFormat) {
Date date = null;
try {
date = new SimpleDateFormat(strFormat).parse(strValue);
} catch (ParseException e) {
}
return date;
}

public static String dateToString(Date dateValue, String strFormat) {
return new SimpleDateFormat(strFormat).format(dateValue);
}


public static List getDateList(String... dateStr) {

if (dateStr == null || dateStr.length == 0) {
return new ArrayList<>();
}

List result = new ArrayList();

for (String el : dateStr) {
result.add(stringToDate(el, YYYY_MM_DD_HH_MM_SS));
}

return result;
}

private static class TimePair {

private Date startTime;
private Date endTime;

private Long startLong;
private Long endLong;

private String startString;
private String endString;

private int authOverlapCout;
private int stayOverlapCount;


private static final Predicate predicateIsCharge = new Predicate() {
@Override
public boolean test(TimePair timePair) {
return timePair.getStayOverlapCount() > timePair.getAuthOverlapCout();
}
};

private static final Predicate predicateNotInHoliday = new Predicate() {
@Override
public boolean test(TimePair timePair) {
int authOverlapCout = timePair.getAuthOverlapCout();
int stayOverlapCount = timePair.getStayOverlapCount();

//在该时段有停留,但是该时段不在节假日内
return stayOverlapCount > 0 && authOverlapCout == 0;
}
};

public TimePair(Long startLong, Long endLong) {
this(new Date(startLong), new Date(endLong));
}

public TimePair(Date startTime, Date endTime) {
this.startTime = startTime;
this.endTime = endTime;
this.startLOng= startTime.getTime();
this.endLOng= endTime.getTime();
this.startString = dateToString(startTime, YYYY_MM_DD_HH_MM_SS);
this.endString = dateToString(endTime, YYYY_MM_DD_HH_MM_SS);
}

public TimePair(String startString, String endString) {
this.startString = startString;
this.endString = endString;
this.startTime = stringToDate(startString, YYYY_MM_DD_HH_MM_SS);
this.endTime = stringToDate(endString, YYYY_MM_DD_HH_MM_SS);
this.startLOng= this.startTime.getTime();
this.endLOng= this.endTime.getTime();
}


public String getStartString() {
return startString;
}

public void setStartString(String startString) {
this.startString = startString;
}

public String getEndString() {
return endString;
}

public void setEndString(String endString) {
this.endString = endString;
}

public int getStayOverlapCount() {
return stayOverlapCount;
}

public void setStayOverlapCount(int stayOverlapCount) {
this.stayOverlapCount = stayOverlapCount;
}

public Date getStartTime() {
return startTime;
}

public void setStartTime(Date startTime) {
this.startTime = startTime;
}

public Date getEndTime() {
return endTime;
}

public void setEndTime(Date endTime) {
this.endTime = endTime;
}

public Long getStartLong() {
return startLong;
}

public void setStartLong(Long startLong) {
this.startLOng= startLong;
}

public Long getEndLong() {
return endLong;
}

public void setEndLong(Long endLong) {
this.endLOng= endLong;
}

public int getAuthOverlapCout() {
return authOverlapCout;
}

public void setAuthOverlapCout(int authOverlapCout) {
this.authOverlapCout = authOverlapCout;
}


public int caculateOverLapWith(Date startTime, Date endTime) {
if (this.startLOng== null) {
this.startLOng= this.startTime.getTime();
}

if (this.endLOng== null) {
this.endLOng= this.endTime.getTime();
}

int incr = 0;
if (this.startLong >= startTime.getTime() && this.endLong <= endTime.getTime()) {

if (this.startLong != this.endLong) {


incr += 1;
}
}


return incr;
}

public int caculateOverLapWithAuth(Date startTime, Date endTime) {
int incr = caculateOverLapWith(startTime, endTime);
if (incr > 0) {
String startTimeStr = dateToString(startTime, YYYY_MM_DD_HH_MM_SS);
String endTimeStr = dateToString(endTime, YYYY_MM_DD_HH_MM_SS);
System.out.println(Parser.parse1("[包期时间]: ({} ~ {})与时间段({} ~ {})有重叠", this.startString, this.endString, startTimeStr, endTimeStr));
}
this.authOverlapCout += incr;

return this.authOverlapCout;
}

public int caculateOverLapWithStay(Date startTime, Date endTime) {
int incr = caculateOverLapWith(startTime, endTime);
if (incr > 0) {
String startTimeStr = dateToString(startTime, YYYY_MM_DD_HH_MM_SS);
String endTimeStr = dateToString(endTime, YYYY_MM_DD_HH_MM_SS);
System.out.println(Parser.parse1("[停留时间]: ({} ~ {})与时间段({} ~ {})有重叠", this.startString, this.endString, startTimeStr, endTimeStr));
}
this.stayOverlapCount += incr;
return this.stayOverlapCount;
}

public boolean needCharge() {
return predicateIsCharge.test(this);
// return stayOverlapCount > authOverlapCout;
}

public boolean notInHoliday() {
return predicateNotInHoliday.test(this);
}


public int caculateOverLapWithAuth(List dates) {
int count = this.authOverlapCout;
if (dates == null) {
return count;
}

final int batch = 2;

while (dates.size() >= batch) {
List li = dates.subList(0, batch);
count = caculateOverLapWithAuth(li.get(0), li.get(1));
li.clear();
}

return count;
}

public int caculateOverLapWithStay(List dates) {
int count = this.stayOverlapCount;
if (dates == null) {
return count;
}

final int batch = 2;

while (dates.size() >= batch) {
List li = dates.subList(0, batch);
count = caculateOverLapWithStay(li.get(0), li.get(1));
li.clear();
}

return count;
}


@Override
public String toString() {
if (startString == null) {
startString = dateToString(startTime, YYYY_MM_DD_HH_MM_SS);
}

if (endString == null) {
endString = dateToString(endTime, YYYY_MM_DD_HH_MM_SS);
}

return "(" + startString + " ~ " + endString + ") : auth:" + this.authOverlapCout + " stay:" + this.stayOverlapCount;
}
}


private static class Pair {
public A first;
public B second;

public Pair(A first, B second) {
this.first = first;
this.secOnd= second;
}

@Override
public String toString() {
return Parser.parse1("<{}, {}>\n\t",
first instanceof Date ? dateToString((Date) first, YYYY_MM_DD_HH_MM_SS) : first,
second instanceof Date ? dateToString((Date) second, YYYY_MM_DD_HH_MM_SS) : second);
}
}


public interface Predicate {
public boolean test(T t);
}






}



推荐阅读
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
author-avatar
稻米屋321
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有