HDU4515+计算日期
模拟!
/*
计算过了D天后的日期
之前D天的日期
*/
#include<stdio.h>
int judge_year( int year ){
if( (year%==&&year%!=)||(year%==) )
return true;
else
return false;
}
int judge_month( int mon ){
if( mon==||mon==||mon==||mon==||mon==||mon==||mon== )
return true;
else
return false;
}
int main(){
int ca;
//freopen("cmp.txt","w",stdout);
scanf("%d",&ca);
while( ca-- ){
int n;
scanf("%d",&n); int year,mon,day;
year = ;
mon = ;
day = ;
int sum = n;
while( sum> ){
if( judge_year(year)==true ){ //printf("sum=%d,,year = %d,mon=%d,day=%d\n",sum,year,mon,day);
if( mon== ){
int left = -day;
if( sum>left ){
sum = sum-(left+);
mon++;
day = ;
}
else if( sum==left ){
sum = ;
day = ;
}
else {
day += sum;
sum = ;
}
}
else if( judge_month( mon )==true ){
int left = -day;
if( sum>left ){
sum = sum-left-;
mon++;
if( mon> ) {
year++;
mon = ;
}
day = ;
}
else if( sum==left ){
sum = ;
day = ;
}
else{
day += sum;
sum = ;
}
}
else {
int left = -day;
if( sum>left ){
sum = sum-left-;
mon++;
if( mon> ) {
year++;
mon = ;
}
day = ;
}
else if( sum==left ){
sum = ;
day = ;
}
else{
day += sum;
sum = ;
}
} }//闰年
else{ if( mon== ){
int left = -day;
if( sum>left ){
sum = sum-left-;
mon++;
day = ;
}
else if( sum==left ){
sum = ;
day = ;
}
else {
day += sum;
sum = ;
}
}
else if( judge_month( mon )==true ){
int left = -day;
if( sum>left ){
sum = sum-left-;
mon++;
if( mon> ) {
year++;
mon = ;
}
day = ;
}
else if( sum==left ){
sum = ;
day = ;
}
else{
day += sum;
sum = ;
}
}
else {
int left = -day;
if( sum>left ){
sum = sum-left-;
mon++;
if( mon> ) {
mon = ;
year++;
}
day = ;
}
else if( sum==left ){
sum = ;
day = ;
}
else{
day += sum;
sum = ;
}
} }//不是闰年
if( sum<= )
break;
}//向后D天的日期 printf("%04d/%02d/%02d ",year,mon,day);
year = ;
mon = ;
day = ;
sum = n;
while( sum> ){
if( judge_year( year )==true ){
if( sum>= ){
sum-=;
year--;
}
else{
if( mon== ){
int left = day;
if( sum>= ){
sum-=;
mon--;
}
else {
if( sum==left- ){
sum = ;
day = ;
}
else if( sum<left- ){
day -= sum;
sum = ;
}
else {
sum -= left;
day = ;
mon--;
}
}
}
else if( mon==||mon==||mon==||mon== ){
int left = day;
if( sum>= ){
sum-=;
mon--;
}
else {
if( sum==left- ){
sum = ;
day = ;
}
else if( sum<left- ){
day -= sum;
sum = ;
}
else {
sum -= left;
day = ;
mon--;
}
}
}
else {
int left = day;
if( sum>= ){
sum-=;
mon--;
if( mon<= ){
year--;
mon=;
}
}
else {
if( sum==left- ){
sum = ;
day = ;
}
else if( sum<left- ){
day -= sum;
sum = ;
}
else {
sum -= left;
day = ;
mon--;
if( mon== ){
mon = ;
year--;
}
}
}
}
}
}//闰年
else {
if( sum>= ){
sum-=;
year--;
}
else{
if( mon== ){
int left = day;
if( sum>= ){
sum-=;
mon--;
}
else {
if( sum==left- ){
sum = ;
day = ;
}
else if( sum<left- ){
day -= sum;
sum = ;
}
else {
sum -= left;
day = ;
mon--;
}
}
}
else if( mon==||mon==||mon==||mon== ){
int left = day;
if( sum>= ){
sum-=;
mon--;
}
else {
if( sum==left- ){
sum = ;
day = ;
}
else if( sum<left- ){
day -= sum;
sum = ;
}
else {
sum -= left;
day = ;
mon--;
}
}
}
else {
int left = day;
if( sum>= ){
sum-=;
mon--;
if( mon== ){
year--;
mon=;
}
}
else {
if( sum==left- ){
sum = ;
day = ;
}
else if( sum<left- ){
day -= sum;
sum = ;
}
else {
sum -= left;
day = ;
mon--;
if( mon== ){
mon = ;
year--;
}
}
}
}
}
}//不是闰年
if( sum<= ) break;
} printf("%04d/%02d/%02d\n",year,mon,day);
}
return ;
}
HDU4515+计算日期的更多相关文章
- 计算日期时间 自动加1天 PHP计算闰年 java与PHP时间戳对比区别
昨天写一个同步数据库的模块 从一个数据库同步到另外一个数据库,因为数据较多,不可能一次性全部搬迁过去,所以就按照每天搬迁! 写了一个 模块,点击加1,只要点击一次,自动从A数据库取出1天的数据, 并 ...
- js计算日期相差的天数
在网站开发中,经常会遇到计算日期相差的天数,js 没有提供相应的方法,所以自己写一个,方便将来查看: 代码: function DateDiff(sDate1, sDate2, splitStr) { ...
- Java8中计算日期时间差
一.简述 在Java8中,我们可以使用以下类来计算日期时间差异: 1.Period 2.Duration 3.ChronoUnit 二.Period类 主要是Period类方法getYears(),g ...
- sqlserver计算日期
在网上找到的一篇文章,相当不错哦O(∩_∩)O~ 这是计算一个月第一天的SQL 脚本: SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0) --当月的第一 ...
- MySQL计算日期的函数DATE_SUB(d,INTERVAL expr type)
MySQL计算日期的函数DATE_SUB(d,INTERVAL expr type) DATE_SUB(d,INTERVAL expr type)函数返回起始日期d减去一个时间段后的日期. expr是 ...
- PostgreSQL 当月最后一天的工作日 , 计算日期是星期几
可以用pg自带函数select extract(dow from current_date),之所以没用主要是展示一下通过数学方法计算日期的原理. drop function if exists ge ...
- Java程序设计——反转字符串 & 找朋友 & 计算int型二进制1的个数 & 情报加密 & 计算日期 & 求近似数 & 输出较小数(练习1)
作为刚刚入门Java的选手,其实C++的功底起到了很大的作用.但是,Java之于C++最大的不同,我个人认为,是其类的多样性.才入门的我,写着老师布置的简单的面对过程的题,如果是C++,可以算是简单了 ...
- 按年、季度、月分组&&计算日期和时间的函数
Mysql 按年.季度.月分组 按月度分组: select DATE_FORMAT(i.created_at, '%Y-%m月')...................GROUP BY DATE_FO ...
- JavaScript计算日期间隔以及结果错误(少一天)的解决方法
下面的代码是之前从网上某个地方COPY下来的,之前一直用着,前段时间DateDiff()方法突然出问题了,输入两个日期2015-10-01 和 2015-10-02之后,计算出来的日期是0!如果只有几 ...
随机推荐
- scala学习笔记:集合
scala> 1 to 10 res9: scala.collection.immutable.Range.Inclusive = Range(1, 2, 3, 4, 5, 6, 7, 8, 9 ...
- Android Studio依赖dependencies和Eclipse加上lib包解决重复编译某些项目的问题
android运行时编译,可以在android的dependencies里面加语句, 一般是compile 'com.android.support:appcompat-v7:22.2.1' comp ...
- android loadlibrary 更改libPath 路径,指定路径加载.so
http://www.jianshu.com/p/f751be55d1fb 字数549 阅读177 评论0 喜欢0 需求很简单 ,就是加载指定文件夹下的.so. 原因:android在程序运行的状态下 ...
- spring中加入log4j
spring中加入log4j <context-param> <param-name>log4jConfigLocation</param-name> <pa ...
- iOS推送通知流程
①注册推送通知使用方法:registerUserNotificationSettings, registerForRemoteNotifications ④APP发送deviceToken到第三方: ...
- 轮子来袭 vJine.Core Orm 之 03_架构分析
1.vJine.Core ORM 架构: 如上图所示,vJine.Core ORM的特点如下: 所有操作均以DataManager为核心: DataManager业务部分的增删改查操作依赖于Class ...
- nodejs js模块加载
本文地址:http://www.cnblogs.com/jasonxuli/p/4381747.html nodejs的非核心模块(core module)加载主要使用的就是module.js. 项目 ...
- seaJs 使用
开始使用seajs的时候折磨了我好一阵.光是各种概念就让新手难理解.现在弄清楚了,上个实践以备忘.目录结构如图. 1.文件 sea.html main.js a.js b.js c.js 最 ...
- 伪分布式环境下命令行正确运行hadoop示例wordcount
首先确保hadoop已经正确安装.配置以及运行. 1. 首先将wordcount源代码从hadoop目录中拷贝出来. [root@cluster2 logs]# cp /usr/local/h ...
- html标签对应的英文原文
标签 对应英文 说明 <!--> / 注释 <!DOCTYPE> document type 文档类型 <a> anchor 超链接 <abbr> ab ...