LeetCode2409——统计共同度过的日子数

在这里插入图片描述


博主的解法过于冗长,是一直对着不同的案例debug修改出来的,不建议学习。虽然提交成功了,但是自己最后都不知道写的是啥了哈哈哈。
在这里插入图片描述
在这里插入图片描述

package keepcoding.leetcode.leetcode2409;
/*Alice 和 Bob 计划分别去罗马开会。给你四个字符串 arriveAlice ,leaveAlice ,arriveBob 和 leaveBob 。Alice 会在日期 arriveAlice 到 leaveAlice 之间在城市里(日期为闭区间),而 Bob 在日期 arriveBob 到 leaveBob 之间在城市里(日期为闭区间)。每个字符串都包含 5 个字符,格式为 "MM-DD" ,对应着一个日期的月和日。请你返回 Alice和 Bob 同时在罗马的天数。你可以假设所有日期都在 同一个 自然年,而且 不是 闰年。每个月份的天数分别为:[31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]*/
public class Result01 {public static void main(String[] args) {int days = countDaysTogether("08-12","08-26","08-26","10-25");System.out.println(days);}/*输入:arriveAlice = "08-15", leaveAlice = "08-18",arriveBob = "08-16", leaveBob = "08-19"输出:3解释:Alice 从 8 月 15 号到 8 月 18 号在罗马。Bob 从 8 月 16 号到 8 月 19 号在罗马,他们同时在罗马的日期为 8 月 16、17 和 18 号。所以答案为 3 。*/public static int countDaysTogether(String arriveAlice, String leaveAlice, String arriveBob, String leaveBob) {String[] arriveAliceTimeArray = arriveAlice.split("-",2);String[] leaveAliceTimeArray = leaveAlice.split("-",2);String[] arriveBobTimeArray = arriveBob.split("-",2);String[] leaveBobTimeArray = leaveBob.split("-",2);int aliceArriveMonth = Integer.valueOf(arriveAliceTimeArray[0]);int aliceLeaveMonth = Integer.valueOf(leaveAliceTimeArray[0]);int aliceArriveDay = Integer.valueOf(arriveAliceTimeArray[1]);int aliceLeaveDay = Integer.valueOf(leaveAliceTimeArray[1]);int bobArriveMonth = Integer.valueOf(arriveBobTimeArray[0]);int bobLeaveMonth = Integer.valueOf(leaveBobTimeArray[0]);int bobArriveDay = Integer.valueOf(arriveBobTimeArray[1]);int bobLeaveDay = Integer.valueOf(leaveBobTimeArray[1]);if (aliceArriveDay==bobArriveDay && aliceArriveMonth==bobArriveMonth && aliceLeaveDay==bobLeaveDay && aliceLeaveMonth==bobLeaveMonth){if (aliceArriveDay==1 && aliceLeaveMonth==12){return 365;}else if (aliceArriveDay==28 && aliceArriveMonth==2 && aliceLeaveMonth==3){return 2;}}//alice和bob同一个月到if (aliceArriveMonth == bobArriveMonth) {//同一个月走if (aliceLeaveMonth==bobLeaveMonth){if (aliceArriveDay > bobLeaveDay || bobArriveDay > aliceLeaveDay) {//alice/bob到的时候 bob/alice已经走了 共同度过的日子为0return 0;} else {//alice先到if (aliceArriveDay <= bobArriveDay) {return aliceLeaveDay <= bobLeaveDay ? (aliceLeaveDay-bobArriveDay)+1 : (bobLeaveDay-bobArriveDay)+1;//alice后到} else {return aliceLeaveDay <= bobLeaveDay ? (aliceLeaveDay-aliceArriveDay)+1 : (bobLeaveDay-aliceArriveDay)+1;}}//alice走的月份小于bob 即alice先走}else if (aliceLeaveMonth<bobLeaveMonth){if (aliceLeaveDay==bobArriveDay){return 1;}else {int sumDays = aliceLeaveDay;for (int i = aliceArriveMonth+1; i < aliceLeaveMonth; i++) {sumDays += getMonthDays(i);}sumDays += aliceArriveDay>=bobArriveDay ? getMonthDays(aliceArriveMonth)-aliceArriveDay : getMonthDays(bobArriveMonth)-bobArriveDay;return sumDays+1;}//alice走的月份大于bob 即bob先走}else {int sumDays = 0;if (bobArriveMonth==bobLeaveMonth){sumDays += bobLeaveDay - bobArriveDay;}else {sumDays = bobLeaveDay;for (int i = bobArriveMonth+1; i <bobLeaveMonth ; i++) {sumDays += getMonthDays(i);}sumDays += aliceArriveDay>=bobArriveDay ? getMonthDays(aliceArriveMonth)-aliceArriveDay : getMonthDays(bobArriveMonth)-bobArriveDay;}return sumDays+1;}//alice月份先到} else if (aliceArriveMonth < bobArriveMonth) {if (aliceLeaveMonth < bobArriveMonth) {//alice在bob到之前就走了return 0;//alice 走 的那个月 bob 到} else if (aliceLeaveMonth == bobArriveMonth) {if(aliceLeaveDay<=bobLeaveDay){return bobArriveDay < aliceLeaveDay ? (aliceLeaveDay-bobArriveDay)+1 : 0;}else {return bobArriveDay < aliceLeaveDay ? (bobLeaveDay-bobArriveDay)+1 : 0;}//alice在bob到的月份之后的月份才走} else {//bob走的月份小于aliceif (bobLeaveMonth < aliceLeaveMonth) {int sumDays = getMonthDays(bobArriveMonth) - bobArriveDay;for (int i = bobArriveMonth + 1; i < bobLeaveMonth; i++) {sumDays += getMonthDays(i);}sumDays += bobLeaveDay;return sumDays+1;//bob走的月份大于alice} else if (bobLeaveMonth > aliceLeaveMonth) {int sumDays = getMonthDays(bobArriveMonth) - bobArriveDay;for (int i = bobArriveMonth + 1; i < aliceLeaveMonth; i++) {sumDays += getMonthDays(i);}sumDays += aliceLeaveDay;return sumDays+1;//bob跟alice一个月走}else {int sumDays = getMonthDays(bobArriveMonth) - bobArriveDay;for (int i = bobArriveMonth + 1; i < aliceLeaveMonth; i++) {sumDays += getMonthDays(i);}sumDays += Math.min(aliceLeaveDay,bobLeaveDay);return sumDays+1;}}//bob月份先到} else {if (bobLeaveMonth < aliceArriveMonth) {//bob在alice到之前就走了return 0;//bob 走 的那个月 alice 到} else if (bobLeaveMonth == aliceArriveMonth) {return aliceArriveDay < bobLeaveDay ? (bobLeaveDay-aliceArriveDay)+1 : 0;//bob在alice到的月份之后的月份才走} else {//alice走的月份小于bobif (aliceLeaveMonth < bobLeaveMonth) {int sumDays = getMonthDays(aliceArriveMonth) - aliceArriveDay;for (int i = aliceArriveMonth + 1; i < aliceLeaveMonth; i++) {sumDays += getMonthDays(i);}sumDays += aliceLeaveDay;return sumDays+1;//alice走的月份大于bob} else if (aliceLeaveMonth > bobLeaveMonth) {int sumDays = getMonthDays(aliceArriveMonth) - aliceArriveDay;for (int i = aliceArriveMonth + 1; i < bobLeaveMonth; i++) {sumDays += getMonthDays(i);}sumDays += bobLeaveDay;return sumDays+1;//alice跟bob一个月走}else {int sumDays = getMonthDays(aliceArriveMonth) - aliceArriveDay;for (int i = aliceArriveMonth + 1; i < aliceLeaveMonth; i++) {sumDays += getMonthDays(i);}sumDays += Math.min(aliceLeaveDay,bobLeaveDay);return sumDays+1;}}}}//获取月份对应的天数public static int getMonthDays(int i){switch (i){case 1: return 31;case 2: return 28;case 3: return 31;case 4: return 30;case 5: return 31;case 6: return 30;case 7: return 31;case 8: return 31;case 9: return 30;case 10: return 31;case 11: return 30;case 12: return 31;default: return 0;}}
}

官方解较为巧妙,大家可以学习:

在这里插入图片描述
在这里插入图片描述

package keepcoding.leetcode.leetcode2409;
/*
我们可以设计一个函数 calculateDayOfYear 来计算输入中的每个日子在一年中是第几天。
计算输入中的每个日子在一年中是第几天时,可以利用前缀和数组来降低每次计算的复杂度。
知道每个日子是一年中的第几天后,可以先通过比较算出两人到达日子的最大值,离开日子的最小值,然后利用减法计算重合的日子
*/public class Result02 {public static void main(String[] args) {int days = countDaysTogether("10-01","11-01","11-01","12-31");System.out.println(days);}public static int countDaysTogether(String arriveAlice, String leaveAlice, String arriveBob, String leaveBob) {//将每个月份的天数存入数组int[] datesOfMonths = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};//累加数组——计算每个月在这一年已经过了多少天int[] prefixSum = new int[13];for (int i = 0; i < 12; i++) {//i+1 是因为要在数组1-12的位置上一一对应的存入月份累加的天数  eg.一月这一年过了31天   二月过了31+28 三月31+28+31 ...prefixSum[i + 1] = prefixSum[i] + datesOfMonths[i];}//计算alice到的天数是一年的第几天int arriveAliceDay = calculateDayOfYear(arriveAlice, prefixSum);//计算alice走的天数是一年的第几天int leaveAliceDay = calculateDayOfYear(leaveAlice, prefixSum);//计算bob到的天数是一年的第几天int arriveBobDay = calculateDayOfYear(arriveBob, prefixSum);//计算bob走的天数是一年的第几天int leaveBobDay = calculateDayOfYear(leaveBob, prefixSum);//用Math.min(leaveAliceDay, leaveBobDay)计算谁先走的,Math.max(arriveAliceDay, arriveBobDay)计算谁后到的//如果存在共处的时间,先走的-后到的即为共处的天数//如果先走的-后到的 < 0 证明没有相遇共处的时间——return 0;// +1 是因为 如果alice走的那天bob到 根据题意这也算共处了一天 eg .alice 10-01到 10-31走 bob 10-31到 11-3走 ;根据先走的-后到的计算=0,但是有共处的一天,所以+1return Math.max(0, Math.min(leaveAliceDay, leaveBobDay) - Math.max(arriveAliceDay, arriveBobDay) + 1);}//计算是哪一天到的public static int calculateDayOfYear(String day, int[] prefixSum) {//String类的substring()方法 ——截取字符串  https://blog.csdn.net/Crezfikbd/article/details/119708978int month = Integer.parseInt(day.substring(0, 2));int date = Integer.parseInt(day.substring(3));return prefixSum[month - 1] + date;//到的这个月的前一个月总共过了多少天 再加上这个月到的日期 即为这一年的第几天}
}

知道思路后自己又手敲了一遍:

package keepcoding.leetcode.leetcode2409;public class DoItAgain {public static void main(String[] args) {int days = countTogetherDays("10-01","11-01","11-01","12-31");System.out.println(days);}//计算哪天到public static int countTogetherDays(String aliceArrive,String aliceLeave,String bobArrive,String bobLeave){int[] monthDays = {31,28,31,30,31,30,31,31,30,31,30,31};int[] preMonthSum = new int[13];for (int i = 0; i < monthDays.length; i++) {preMonthSum[i+1] = preMonthSum[i] + monthDays[i];}//计算alice一年中的第几天到int aComDay = countDay(aliceArrive,preMonthSum);//计算alice一年中的第几天走int aGoDay = countDay(aliceLeave,preMonthSum);//计算bob一年中的第几天到int bComDay = countDay(bobArrive,preMonthSum);//计算bob一年中的第几天走int bGoDay = countDay(bobLeave,preMonthSum);if (bComDay>aGoDay || aComDay>bGoDay){//没有相遇return 0;}else {//先走的-后到的日期return  Math.min(aGoDay,bGoDay) - Math.max(aComDay,bComDay) + 1;}}//计算各个时间点是这一年的第多少天public static int countDay(String s,int[] preMonthSum){//转化截取的字符串——得到到达的月份、日期int month = Integer.parseInt(s.substring(0,2));int day = Integer.parseInt(s.substring(3));//根据累加的数组结合当月到达的日期    计算到达的天数return preMonthSum[month-1]+day;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/114278.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

分发糖果[困难]

优质博文&#xff1a;IT-BLOG-CN 一、题目 n个孩子站成一排。给你一个整数数组ratings表示每个孩子的评分。你需要按照以下要求&#xff0c;给这些孩子分发糖果&#xff1a; 【1】每个孩子至少分配到1个糖果。 【2】相邻两个孩子评分更高的孩子会获得更多的糖果。 请你给每个孩…

浅谈 docker run 命令中的 -i -t 和 -d 选项

以 docker Ubuntu 镜像为例&#xff0c;ubuntu镜像启动时默认执行的命令是"/bin/bash"。 文章目录 不带任何选项带 -i 选项带 -i 和 -t 选项-d 选项 不带任何选项 rootubuntu20:~# docker run ubuntu:20.04 rootubuntu20:~# docker ps CONTAINER ID IMAGE …

DDOS攻击的有效防护方式有哪些?

DDoS攻击简介&#xff1a; DDoS攻击&#xff0c;即分布式拒绝服务攻击&#xff08;Distributed Denial of Service&#xff09;&#xff0c;是一种网络攻击&#xff0c;旨在通过向目标服务器发送大量恶意请求&#xff0c;使服务器资源耗尽&#xff0c;无法满足合法用户的需求&a…

网络协议--ARP:地址解析协议

4.1 引言 本章我们要讨论的问题是只对TCP/IP协议簇有意义的IP地址。数据链路如以太网或令牌环网都有自己的寻址机制&#xff08;常常为48 bit地址&#xff09;&#xff0c;这是使用数据链路的任何网络层都必须遵从的。一个网络如以太网可以同时被不同的网络层使用。例如&#…

git创建与合并分支

文章目录 创建与合并分支分支管理的概念实际操作 解决冲突分支管理策略Bug分支Feature分支多人协作 创建与合并分支 分支管理的概念 分支在实际中有什么用呢&#xff1f;假设你准备开发一个新功能&#xff0c;但是需要两周才能完成&#xff0c;第一周你写了50%的代码&#xf…

《动手学深度学习 Pytorch版》 9.6 编码器-解码器架构

为了处理这种长度可变的输入和输出&#xff0c; 可以设计一个包含两个主要组件的编码器-解码器&#xff08;encoder-decoder&#xff09;架构&#xff1a; 编码器&#xff08;encoder&#xff09;&#xff1a;它接受一个长度可变的序列作为输入&#xff0c;并将其转换为具有固定…

React +AntD + From组件重复提交数据(已解决)

开发场景&#xff1a; react Hooks andt 提交form表单内容给数据库(使用antd的form组件) 问题描述 提交是异步的&#xff0c;请提交方式是POST 方式 提交表单内容给后端&#xff0c;却产生了两次提交记录&#xff08;当然&#xff0c;数据新增了两条数据&#xff09;。可以…

基于WebRTC的程序因虚拟内存不足导致闪退问题的排查以及解决办法的研究

目录 1、WebRTC简介 2、问题现象描述 3、将Windbg附加到目标进程上分析 3.1、Windbg没有附加到主程序进程上&#xff0c;没有感知到异常或中断 3.2、Windbg感知到了中断&#xff0c;中断在DebugBreak函数调用上 3.3、32位进程用户态虚拟地址和内核态虚拟地址的划分 …

分享5个解决msvcp140.dll丢失的方法,全面解析msvcp140.dll丢失的原因

一、MSVCP140.dll是什么&#xff1f; 首先&#xff0c;我们需要了解什么是MSVCP140.dll。MSVCP140.dll是一个动态链接库文件&#xff0c;它是Microsoft Visual C 2015 Redistributable的一部分。这个文件包含了运行使用C编写的应用程序所需的一些函数和类。因此&#xff0c;当…

MongoDB URL链接 如何设置账号密码

个人博客&#xff0c;求关注。。 MongoDB URL链接 如何设置账号密码 假设你的账号是root&#xff0c;你的密码也是root&#xff0c;则 mongodb://username:passwordlocalhost:27017完美&#xff0c;再见。

探索LLM在图上学习的潜力10.14 暂停

探索LLM在图上学习的潜力 摘要介绍初步知识 摘要 Learning on Graph已经引起了极大的关注&#xff0c;因为它在现实世界中有广泛的应用。在具有文本节点属性的图形上进行学习的最流行的流程主要依赖于图神经网络&#xff08;GNN&#xff09;&#xff0c;并利用浅层文本嵌入作为…

Maven系列第8篇:大型Maven项目,快速按需任意构建

本篇涉及到的内容属于神技能&#xff0c;多数使用maven的人都经常想要的一种功能&#xff0c;但是大多数人都不知道如何使用&#xff0c;废话不多说&#xff0c;上干货。 需求背景 我们需要做一个电商项目&#xff0c;一般都会做成微服务的形式&#xff0c;按业务进行划分&am…

【LeetCode 算法专题突破】滑动窗口(⭐)

文章目录 前言1. 长度最小的子数组题目描述代码 2. 无重复字符的最长子串题目描述代码 3. 最大连续1的个数 III题目描述代码 4. 将 x 减到 0 的最小操作数题目描述代码 5. 水果成篮题目描述代码 6. 找到字符串中所有字母异位词题目描述代码 7. 串联所有单词的子串题目描述代码 …

关于我对 jeecg-boot 的项目理解、使用心得和改进建议

一句话总结&#xff1a; JeecgBoot帮助我提升了后端技术水平&#xff0c;入门了前端&#xff0c;让我在公司内部慢慢能够成长为全栈开发。 一、项目理解 JeecgBoot 项目的核心理念是快速开发、低代码、易扩展。它采用了前后端分离的架构&#xff0c;后端使用Spring Boot Myba…

用节点亲和性把 Pod 分配到节点

用节点亲和性把 Pod 分配到节点 当前集群信息&#xff1a; rootk8s-master:~# kubectl get node -o wide NAME STATUS ROLES AGE VERSION INTERNAL-IP EXTERNAL-IP OS-IMAGE KERNEL-VERSION CONTAINER-RUNTIME k8s…

微信小程序OA会议系统数据交互

前言 经过我们所写的上一文章&#xff1a;微信小程序会议OA系统其他页面-CSDN博客 在我们的是基础面板上面&#xff0c;可以看到出来我们的数据是死数据&#xff0c;今天我们就完善我们的是数据 后台 在我们去完成项目之前我们要把我们的项目后台准备好资源我放在我资源中&…

学习笔记---0基础+干货满满的单链表专题~~

目录​​​​​​​ 1. 链表的概念及结构&#x1f451; 1.1 什么是链表&#xff1f;&#x1f440; 1.2 为什么需要链表&#xff1f;⁉️ 1.3 链表的结构是怎么样的&#xff1f;❓ 2. 链表的分类&#x1f99c; 3. 实现单链表&#x1faf5; 3.1 要实现的目标&#x1f3af;…

JS加密/解密之闭包的运用

深入探讨JavaScript闭包的演变与应用 摘要&#xff1a; 本文将深入探讨JavaScript闭包的概念、特性以及其在实际开发中的应用。我们将从闭包的起源开始&#xff0c;探讨它在JavaScript编程中的重要性&#xff0c;并通过实例展示闭包在不同场景下的灵活应用。 引言 JavaScrip…

第一个Vue程序

首先下载vue.min.js或者vue.js Installation — Vue.js 在web文件下创建js文件并把vue.js复制到此文件。 创建一个jsp文件 显示界面