vijos--P1211--生日日数(纯模拟)
2015-11-24 21:28
387 查看
P1211生日日数
未递交
标签:[显示标签]
未递交
标签:[显示标签]
描述
CCC老师的生日是YY年MM月DD日,他想知道自己出生后第一万天纪念日的日期(出生日算第0天)。格式
输入格式
从文件的第一行分别读入YY,MM,DD其中1949<=YY<=2006,日期绝对合法。输出格式
输出文件只有一行,即CCC老师生日第一万天以后的日期,格式为 “Y-M-D”。样例1
样例输入1[复制]
1979 4 16
样例输出1[复制]
2006-9-1
#include<stdio.h> #include<string.h> int a[13]={0,31,28,31,30,31,30,31,31,30,31,30,31}; int b[13]={0,31,29,31,30,31,30,31,31,30,31,30,31}; int main() { int y,m,d,sum; scanf("%d%d%d",&y,&m,&d); { int k=10000,i,j; int yy; if(y%100!=0&&y%4==0||y%400==0) { sum=366; for(int i=1;i<m;i++) sum-=b[i]; } else { sum=365; for(int i=1;i<m;i++) sum-=a[i]; } sum-=d; k-=sum; yy=y+1; while(k>=365) { if(yy%100!=0&&yy%4==0||yy%400==0) k-=366; else k-=365; yy++; } if(yy%100!=0&&yy%4==0||yy%400==0) { for(i=1;i<=12;i++) { if(k>31&&(i==1||i==3||i==7||i==5||i==8||i==10||i==12)) k-=31; else if(k>30&&(i==4||i==6||i==9||i==11)) k-=30; else if(i==2&&k>29) k-=29; else break; } } else { for(i=1;i<=12;i++) { if(k>31&&(i==1||i==3||i==7||i==5||i==8||i==10||i==12)) k-=31; else if(k>30&&(i==4||i==6||i==9||i==11)) k-=30; else if(i==2&&k>28) k-=28; else break; } } if(k==0&&i==1) printf("%d-12-31\n",yy-1); else printf("%d-%d-%d\n",yy,i,k); } return 0; }
相关文章推荐
- 没有躲过的坑--类中的静态成员变量(static or const static)
- SQL server 变量、运算符
- 没有躲过的坑--类中的静态成员变量(static or const static)
- codeforce #320E Weakness and Poorness (三分)
- error MSB4018 “CL”任务意外失败
- Kendo UI的datasource批量更新的扩展方法
- vijos--P1211--生日日数(纯模拟)
- Linus Bash Shell 的特殊变量和关系运算符
- WIN 7 64位环境中配置vs2015+opencv3.0
- iOS 系统架构及常用框架
- Linux进程冻结技术
- MIT算法导论-第11讲-动态规划
- 为什么匿名内部类和局部内部类只能访问final变量
- hdu 1385 Minimum Transport Cost(Floyd打印路径)
- 剑指offer 66题 下篇
- android局域网通信( 一)
- Node.js(4) -- 七天学会node.js(2)
- magento 中常见的js冲突
- java集合
- ORACLE数据库文件迁移