[2005]:第几天
2015-10-30 09:23
344 查看
第几天?
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 104826 Accepted Submission(s): 38724
Problem Description
给定一个日期,输出这个日期是该年的第几天。
Input
输入数据有多组,每组占一行,数据格式为YYYY/MM/DD组成,具体参见sample input ,另外,可以向你确保所有的输入数据是合法的。
Output
对于每组输入数据,输出一行,表示该日期是该年的第几天。
Sample Input
1985/1/20
2006/3/12
Sample Output
20
71
思路:分别对年月日进行判断
这道题在C++prime 里面有类似的,可以看一下
下面是我第一次运行的,本地可以,但是是WA:
而且对问题还没有相对的简化
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 104826 Accepted Submission(s): 38724
Problem Description
给定一个日期,输出这个日期是该年的第几天。
Input
输入数据有多组,每组占一行,数据格式为YYYY/MM/DD组成,具体参见sample input ,另外,可以向你确保所有的输入数据是合法的。
Output
对于每组输入数据,输出一行,表示该日期是该年的第几天。
Sample Input
1985/1/20
2006/3/12
Sample Output
20
71
思路:分别对年月日进行判断
#include<stdio.h> int main() { int year, month, day, Feb, month1, i, sum; char tag1, tag2; while(scanf("%d%c%d%c%d", &year, &tag1, &month, &tag2, &day)!=EOF){ sum = 0; month1 = month-1; if(year%400==0||(year%100!=0&&year%4==0)){ Feb = 29; } else{ Feb = 28; } for(i=1;i<=month1;i++){ if(i==1||i==3||i==5||i==7||i==8||i==10){ sum += 31; } else if(i== 2){ sum += Feb; } else{ sum += 30; } } sum += day; printf("%d\n", sum); } return 0; }
这道题在C++prime 里面有类似的,可以看一下
#include <iostream> #include <cstdio> using namespace std; int main(void) { int days[12] = { 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; int y, m, d; while (scanf("%d/%d/%d", &y, &m, &d) != EOF) { if (y % 4 != 0 || (y % 100 == 0 && y % 400 != 0)) { days[1] = 28; } else days[1] = 29; int day=0; if (m == 1) { for (int i = 1; i < m; i++) day += days[i]; } else { for (int i = 0; i < m-1; i++) day += days[i]; } day += d; cout << day << endl; } return 0; }
下面是我第一次运行的,本地可以,但是是WA:
#include<stdio.h> int main() { int year, month, day, Feb, month1, k, i, sum; char tag1, tag2; while(scanf("%d%c%d%c%d", &year, &tag1, &month, &tag2, &day)!=EOF){ sum = 0; if(year%400==0||(year%100!=0&&year%4==0)){ Feb = 29; } else{ Feb = 28; } if(month<=7 ){ if(month>2){ if(month%2!=0){ i = (month-1)/2; sum += (31 * i + 30 * (i-1) + Feb) ; } else{ sum += (30 * (month/2-2) + 31 * month/2 + Feb); } } else if(month == 2){ sum += (Feb + 31); } else{ sum = 0; } } else if(month>=8 && month<=12){ sum += (4 * 31 + 2 * 30 + Feb); if(month%2==0){ sum += 31 * (month/2-4) + 30 * (month/2-4); } else{ sum += 30 * ((month-1)/2-4) + 31 * ((month-1)/2-3); } } sum += day; printf("%d\n", sum); } return 0; }
而且对问题还没有相对的简化
相关文章推荐
- 对于org.apache.commons.dbcp.BasicDataSource的配置认知
- python操作mysql数据库
- ArrayList、string、string[]之间的转换
- 第九周项目2 - 对称矩阵压缩存储的实现与应用(2)
- 第8周项目4 字符串加密
- Ubuntu 下安装minicom 及配置过程
- 基于用户认证来实现不同域的邮件转发
- 对称矩阵压缩存储的实现与应用(1)
- 优化哈希策略
- symfony
- 在页面和请求中分别使用XML Publisher生成PDF报表且自动上传至附件服务器
- .NET NLog 详解(二)
- NSLocale
- NSOrderedSet
- 文件I/O编程之sync、fsync和fdatasync函数
- android:关于主工程和library project
- C语言开发环境配置
- 第九周项目2 —对称矩阵压缩存储的实现与应用(1)
- 第10周 项目1—二叉树算法库
- 第九周项目2-对称矩阵压缩存储的实现和应用(1)