一、题目描述如下:

二、思路分析

  其实这个如果是一个填空题,可以直接用Excel快速计算出来,反而用代码比较麻烦

说一下我的代码的思路:

1.如果N大于本月剩下的天数,就先从N天里减去本月剩下的天数,

2.如果剩下的N天大于本年剩下的天数,就从N天里减去本年剩下的天数,这时候日期为YYYY+1年 1月 1日

3.因为闰年每四年一次,可以从N里面减去k个365*3+366天,直到N小于365*3+366,这时日期为YYYY+1+k年 1月 1日

4.从N里面减去t个当前年的天数(平年为365,闰年为366),直到N小于当前年的天数,这时候日期为YYYY+1+k+t年 1月 1日

5.从N里面减去p个月的天数,直到剩下的N不够本月的天数,这时候就能得到最后的日期为YYYY+1+k+t年 p月 N日

6.星期很好算,直接用(W+N)%7就能得到最后的星期

三、根据思路,Java代码如下(如有其他思路,恭请各位大佬评论区评论,我觉得我的思路太麻烦)

import java.util.Scanner;
public class Main1 {
static Scanner sc = new Scanner(System.in);
static int j = sc.nextInt();
static String str;
static int year,month,day,w,N,m,monthDay;
static int temp = 366+365*3;
public static void main(String[] args) {
for (int i = 0; i < j; i++) {
str = sc.next();
year = Integer.parseInt(str.substring(0, 4));
month = Integer.parseInt(str.substring(4,6));
day = Integer.parseInt(str.substring(6,8));
w =sc.nextInt();
N = (int) sc.nextLong();
m = (int) (N/temp);
w = (w+N)%7;//6.星期很好算,直接用(W+N)%7就能得到最后的星期
days();//1.如果N大于本月剩下的天数,就先从N天里减去本月剩下的天数,
months();//2.如果剩下的N天大于本年剩下的天数,就从N天里减去本年剩下的天数,这时候日期为YYYY+1年 1月 1日
years();//3.因为闰年每四年一次,可以从N里面减去k个365*3+366天,直到N小于365*3+366,这时日期为YYYY+1+k年 1月 1日
year();//4.从N里面减去t个当前年的天数(平年为365,闰年为366),直到N小于当前年的天数,这时候日期为YYYY+1+k+t年 1月 1日
months();//5.从N里面减去p个月的天数,直到剩下的N不够本月的天数,这时候就能得到最后的日期为YYYY+1+k+t年 p月 N日
System.out.println(year+""+String.format("%02d", month)+""+String.format("%02d", day)+" "+w);
} } //从N里面减去本月剩下的天数
static void days(){
monthDay = getdays(year,month);
if(day+N>monthDay){
N=N+day-monthDay-1;
day=1;
month++;
}else{
day+=N;
N=0;
}
} //从N里面减去p月的天数,直到N小于本月天数或者月数大于12
static void months(){
monthDay = getdays(year,month);
while(month<=12 && N>=monthDay){
if(N==0){
break;
}else{
month++;
day=1; if(N>=monthDay)
N-=monthDay;
else{
day=N;
break;
}
}
}
if(month==13){
month=1;
year++;
}else{
day+=N;
N=0;
} } //从N里面减去k个四年
static void years(){
while(N>temp){
year+=4;
N-=temp;
}
} //从N里面减去当前年的天数,直到N小于当前年的天数
static void year(){
int nowyear = getYear(year);
while(N>=nowyear){
year++;
N-=nowyear;
nowyear = getYear(year);
}
} //判断是否是闰年
static boolean jugeYear(int year){
if(year %4==0&&year%100!=0 || year%400==0)
return true;
return false;
} //获取当前年的天数
static int getYear(int year){
int nowyear = 365;
if(jugeYear(year))
nowyear = 366;
return nowyear;
} //获取当前月的天数
static int getdays(int year,int month){
if(month==1 || month==3 || month==5 || month==7 || month==8 || month==10 || month==12)
return 31;
else if(month==4 || month==6 || month==9 || month==11 )
return 30;
else{
if(jugeYear(year))
return 29;
else
return 28;
}
}
}

ACM 第十一届 河南省省赛A题 计划日的更多相关文章

  1. Checkpoints(第十一届河南省省赛真题)

    题目描述 As a landlocked country in central and southern Africa , the political situation has been relat ...

  2. 求XF+闭包(第十一届河南省省赛真题)

    题目描述 如何设计一个好的数据库不仅仅是一个理论研究问题,也是一个实际应用问题.在关系数据库中不满足规范化理论的数据库设计会存在冗余.插入异常.删除异常等现象. 设R(U)是一个关系模式,U={ A1 ...

  3. Substrings 第37届ACM/ICPC 杭州赛区现场赛C题(hdu 4455)

    http://acm.hdu.edu.cn/showproblem.php?pid=4455 https://icpcarchive.ecs.baylor.edu/index.php?option=c ...

  4. hdu 4431 第37届ACM/ICPC 天津赛区现场赛A题 枚举

    题意:就是给了13张牌.问增加哪些牌可以胡牌.m是数字,s是条,p是筒,c是数字 胡牌有以下几种情况: 1.一个对子 +  4组 3个相同的牌或者顺子.  只有m.s.p是可以构成顺子的.东西南北这样 ...

  5. ACM 2015年上海区域赛A题 HDU 5572An Easy Physics Problem

    题意: 光滑平面,一个刚性小球,一个固定的刚性圆柱体 ,给定圆柱体圆心坐标,半径 ,小球起点坐标,起始运动方向(向量) ,终点坐标 ,问能否到达终点,小球运动中如果碰到圆柱体会反射. 学到了向量模板, ...

  6. hdu 4438 第37届ACM/ICPC 天津赛区现场赛H题

    题意:Alice和Bob两个人去打猎,有两种(只)猎物老虎和狼: 杀死老虎得分x,狼得分y: 如果两个人都选择同样的猎物,则Alice得分的概率是p,则Bob得分的概率是(1-p): 但是Alice事 ...

  7. zoj 3659 第37届ACM/ICPC 长春赛区现场赛E题 (并查集)

    题意:给出一棵树,找出一个点,求出所有点到这个点的权值和最大,权值为路径上所有边权的最小值. 用神奇的并查集,把路按照权值从大到小排序,然后用类似Kruskal的方法不断的加入边. 对于要加入的一条路 ...

  8. sdut 2162:The Android University ACM Team Selection Contest(第二届山东省省赛原题,模拟题)

    The Android University ACM Team Selection Contest Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里 ...

  9. Sdut 2409 The Best Seat in ACM Contest(山东省第三届ACM省赛 H 题)(模拟)

    题目描述 Cainiao is a university student who loves ACM contest very much. It is a festival for him once ...

随机推荐

  1. (Review cs231n) Object Detection

    目标:我们有几个类别,然后我们要在这张图中找到这些类的所有实例 解决思路:是否可以按照回归的思路进行求解呢? 但是受限制于确定的种类输出问题. 方法:分类和回归是解决问题的两个套路,我们现在对于目标的 ...

  2. Eclipse中启动Tomcat报错:[There is insufficient memory for the Java Runtime Environment to continue.]的解决方案

    1,报错截图 2,报错信息 五月 08, 2018 9:57:58 上午 org.apache.tomcat.util.digester.SetPropertiesRule begin 警告: [Se ...

  3. 【Diary】期中考+春游记

    4.22-4.24 期中考 周一 早上 赶来三楼电教厅自习,疯狂复习历史.想到下午考语文历史两大文科,不由得有点慌吧. 突然,沙雕体委说了一句: 下午考政治,你不背诵吗 下午 语文感觉正常发挥. 政治 ...

  4. 在linux和windows用c++编写c接口的动态库

    linux 动态的头文件api.h #ifndef _API_H #define _API_H #ifdef DLL_IMPLEMENT #define DLL_EXPORT extern " ...

  5. 算法(第四版)C# 习题题解——2.2

    写在前面 整个项目都托管在了 Github 上:https://github.com/ikesnowy/Algorithms-4th-Edition-in-Csharp 查找更为方便的版本见:http ...

  6. 如何加速GitHub访问速度

    http://tool.chinaz.com/网站中填入assets-cdn.github.com选取响应最小的ip,将ip.域名填入到C:\Windows\System32\drivers\etc下 ...

  7. 多邻国学英语 tips

    来源: https://www.cnblogs.com/daysme整理了一分多邻国学英语中的相关语法文档. 地方 null 现在完成时 null 反身代词 浓缩的精华:反身代词就是 “XX 自己” ...

  8. 一键快速部署CodeBlocks的EGE图形库工具

    大一下学期,学完了c语言的基本内容, 也就开始开发项目了,此时一个图形界面就比较重要了,c语言中不提供图形界面,一般这些是用的其它开发的图形库,如 Easyx .ege等. 本文就提供 Codeblo ...

  9. [IoC容器Unity]第四回:使用范例

    1.引言 前面几个章节介绍了Unity的基本使用,主要分为程序和配置文件两种方法的使用,可以参考一下链接, [IoC容器Unity]第一回:Unity预览 [IoC容器Unity]第二回:Lifeti ...

  10. python-request-各方法使用及格式

    Request库方法介绍 方法 说明 requests.request() 构造一个请求,支撑一下各方法的基础方法  requests.get()  获取HTML网页的主要方法,对应于HTTP的GET ...