工具类-滑动窗口判断是否存在最大连续日期

工具类-滑动窗口判断是否存在最大连续日期

使用场景:判断是否存在连续的N天。

package com.demo;

import java.util.HashSet;
import java.util.List;
import java.util.stream.Collectors;

/**
 * @Author ccl
 * @Date 2021/6/10 16:09
 */
public class Demo {

    public static void main(String[] args) {
        HashSet<Integer> days = new HashSet<>();
        days.add(20210601);
        days.add(20210602);
        days.add(20210603);

        days.add(20210605);
        days.add(20210606);
        days.add(20210607);
        //days.add(20210608);
        //days.add(20210609);

        days.add(20210611);
        //days.add(20210612);
        days.add(20210614);
        days.add(20210613);
        days.add(20210616);

        boolean flag = hasContinuousDate(days, 2);
        System.out.println(flag);
    }

    private static boolean hasContinuousDate(HashSet<Integer> days, int continueMax) {
        if (days.size() < continueMax) {
            return false;
        }
        boolean flag = false;
        int count = 1;
        int preDay = 0;
        final List<Integer> list = days.stream().sorted().collect(Collectors.toList());
        for (Integer day : list) {
            if (day - preDay == 1) {
                count++;
            } else {
                count = 1;
            }
            preDay = day;
            if (count >= continueMax) {
                flag = true;
                break;
            }
        }
        return flag;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值