题目描述
请你计算出第X年Y月Z日是第X年的第几天。其中,1月1日是第一天,1月2日是第二天,以此类推。
计算时请注意闰年的影响。对于非整百年,年数能整除4是闰年,否则不是闰年;对于整百年,年数能整除400是闰年,否则不是闰年。如1900年和1901年不是闰年,而2000年和2004年是闰年。
输入格式:
第一行有一个整数T (T≤100),表示一共有T组数据需要你处理。
接下来一共有T行,每行是一个如下格式的字符串:X:Y:Z,表示你需要计算第X年Y月Z日是第X年的第几天。其中X是一个大于0,小于2100的整数。保证字符串的格式都是合法的,字符串所表示的日期也都是存在的。
输出格式:
对于每组数据,你需要输出一个整数,表示所求得的结果。
输入样例
2
2013:4:12
112:4:12
输出样例
102
103
算法思路:输入一个string型字符串str,从头遍历遇到第一个’:'时停止,拷贝到char数组中,再把char[]转string,在用atoi转int,(其实有点脱裤子放屁,请自行改进…),再把str已经识别的删掉,同理再进行下一次识别,…最后判一下闰年,ok,没有判越界啥的…
#include<bits/stdc++.h>//万能头文件,如果编译器不支持的话,自己加~
using namespace std;
int date[13] = {0,31,28,31,30,31,30,31,31,30,31,30,31};
int main()
{
int T;
cin>>T;//表示几组数据
cin.get();//因为下面有getline,上面有cin,会有bug影响输入,所以要加这一句,自行百度
while(T--)
{
string str;//输入字符串
getline(cin,str);//接收str
//cout<<"str="<<str<<endl;
char n[4]={0},y[5]={0},r[5]={0};
int i=0,j=0,k=0;
for(;str[i]!=':';i++)
{
n[i]=str[i];//拷贝到char[]
}
string nn = n;//char转string
int nn1 = atoi(nn.c_str());//string转int
str.erase(0,i+1);//删除识别的str,此处即年份和':'
//cout<<"nn1="<<nn1<<endl;
for(;str[j]!=':';j++)
{
y[j]=str[j];
}
str.erase(0,j+1);
string yy = y;
int yy1 = atoi(yy.c_str());
//cout<<"yy1="<<yy1<<endl;
for(;k<str.length();k++)
{
r[k] = str[k];
}
string rr = r;
int rr1 = atoi(rr.c_str());
// cout<<"rr1="<<rr1<<endl;
int day = 0;
for(int i = 1;i<yy1;i++)
{
day += date[i];
}
//cout<<"day="<<day<<endl;
day+=rr1;
if((nn1%100!=0 && nn1%4==0 )|| nn1%400==0)
{
if(yy1>2)
{
day++;
}
}
cout<<day<<endl;
}
return 0;
}
补充:
用这个简单多了,scanf("%d:%d:%d",&x,&y,&z); 直接识别…