杭电oj2005 第几天

博主分享杭电oj 2005第几天的解题情况,称自己做这道题感觉还行,代码比搜出来的还少些,是经过不少计算得出的,将代码发出供参考。

杭电oj 2005 第几天

刚做了一下2005
感觉还行,发现我的代码比搜出来的还少点

当然了,我算了不少
发出来,仅供参考

#include<stdio.h>
int main()
{
 int a,b,c,out=0;
 int d[13]={0,0,31,59,90,120,151,181,212,243,273,304,334};
 int e[13]={0,0,31,60,90,121,152,182,213,244,274,305,335};
 while(scanf("%d/%d/%d",&a,&b,&c)!=EOF)
 {
      if(a%4==0&&a%100!=0 || a%400==0)
     {
         out=e[b]+c;
      }else
     {
         out=d[b]+c;
     }
      printf("%d\n",out);
     }
 return 0;
}
以下为同编程语言在杭电OJ上实现输入年月日计算当年第几天的代码示例: ### C++ 实现 ```cpp #include <iostream> using namespace std; int main() { int year, day, month, days; while (cin >> year >> month >> day) { days = 0; int months[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31}; if (year % 400 == 0 || (year % 4 == 0 && year % 100 != 0)) { months[2] = 29; } for (int i = 1; i < month; i++) { days += months[i]; } cout << days + day << endl; } return 0; } ``` 此代码从标准输入读取年月日,通过判断是否为闰年调整2月的天数,再累加前几个月的天数与当前日期得到该天是当年的第几天并输出结果[^1]。 ### Java 实现 ```java import java.util.Scanner; public class hd2005 { public static void main(String[] args) { Scanner scan = new Scanner(System.in); int[] mon1 = {0,31,28,31,30,31,30,31,31,30,31,30,31}; int[] mon2 = {0,31,29,31,30,31,30,31,31,30,31,30,31}; while(scan.hasNext()){ String str = scan.nextLine(); String[] date = str.split("/"); int year = Integer.parseInt(date[0]); int month = Integer.parseInt(date[1]); int day = Integer.parseInt(date[2]); int sum = 0; if(year % 4 == 0 && year % 100 != 0) { for(int i = 1; i < month; i++) { sum += mon2[i]; } } else if(year % 100 == 0 && year % 400 == 0) { for(int i = 1; i < month; i++) { sum += mon2[i]; } } else { for(int i = 1; i < month; i++) { sum += mon1[i]; } } sum += day; System.out.println(sum); } } } ``` 该Java代码使用`Scanner`读取输入,以`/`分割输入字符串得到年月日,依据闰年规则选择同的月份天数数组进行累加,最后输出结果[^2]。 ### 输入含斜杠的 C++ 实现 ```cpp #include <iostream> using namespace std; int main() { int year, month, day; char str1, str2; while (cin >> year >> str1 >> month >> str2 >> day) { int months[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 }; int days = 0; if (year % 400 == 0 || (year % 4 == 0 && year % 100 != 0)) { months[2] = 29; } for (int i = 1; i < month; i++) { days += months[i]; } days += day; cout << days << endl; } return 0; } ``` 此代码支持输入格式为`YYYY/MM/DD`,用字符变量过渡斜杠,后续计算当年第几天的逻辑与之前的 C++ 代码相同[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值