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!如果只有几 ...
随机推荐
- 结果集一组数据的第几条ROW_NUMBER基本用法
因为项目中用到,今天来记录下 ROW_NUMBER的用法. 说明:返回结果集分区内行的序列号,每个分区的第一行从 1 开始. 语法:ROW_NUMBER () OVER ([ <partitio ...
- 认识JSON
JSON 全称 JavaScript Object Notation,意思是JavaScript对象表示法.是一种基于文本的.独立于语言的轻量级数据交换格式.易于阅读和编写,易于机器解析和生成. 一. ...
- Array.splice返回值是数组
import flash.display.MovieClip; import flash.display.DisplayObject; var m:MovieClip = new MovieClip( ...
- 谱曲软件-MuseScore
谱曲软件-MuseScore 参考: 1.MuseScore官网 2.免费乐谱制作软体MuseScore
- (hdu)2444 The Accomodation of Students 判断二分图+最大匹配数
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=2444 Problem Description There are a group of s ...
- 程序员面试题精选100题(33)-在O(1)时间删除链表结点[数据结构]
作者:何海涛 出处:http://zhedahht.blog.163.com/ 题目:给定链表的头指针和一个结点指针,在O(1)时间删除该结点.链表结点的定义如下: struct ListNode { ...
- RabbitMQ远程访问配置
1 首先创建一个新的账户 并给上Administrator标签 2然后给这个新账户添加虚拟主机访问权限 3在windows 下的 rabbitmq安装文件下的etc文件下的配置文件添加以下 [ ...
- MySQL企业常用集群图解
mysql集群架构图片 1.mysql企业常用集群架构 在中小型互联网的企业中.mysql的集群一般就是上图的架构.WEB节点读取数据库的时候读取dbproxy服务器.dbproxy服务器通过对S ...
- [转]优化PHP程序的方法
1. If a method c++an be static, declare it static. Speed improvement is by a factor of 4. 如果一个方法可静态化 ...
- Linux---vi编辑器必会操作
移动光标: (1)基本的上下左右:通过箭头按键控制 (2)跳到一行的末尾:键盘"end" (3)跳到一行的开头:键盘"home" (4)跳到最后一行:shift ...