有一个帅小伙一直暗恋一个女孩,但他还是没有勇气向她表白“我爱你”,更别说“某某某,我爱你,如果非要在这份‘爱’上加一个期限的话,那就是一万年”这类肉麻的话,生怕说了后会是“落花有意流水无情”,连朋友都无法做。不过,在经过一阵思想斗争以后,最后终于还是鼓起勇气向那个女孩进行了表白。女孩没有直接回复他,说了如下这段话: 我知道你一直在关心我,我了解你的心意,但我已经有心仪的人了,我的答案在下面这个问题里,你写出程序看看结果就知道啦。 问题是这样的:你的生日和我的生日之差,如果x是奇数,则结果是“对不起,有缘无份”,如果是偶数,则结果是“傻瓜,我心仪的人其实是你呀!”。 请你编写一个程序判断两人是否能在一起!
输入格式:
输入有2行,第1行表示男生的出生日期,第2行表示女生的出生日期。
输出格式:
首先输出两人生日相隔的天数,如果两人的生日相隔天数是奇数,则输出“对不起,我们有缘无份”,如果是偶数,则输出“傻瓜,我心仪的人其实是你呀!”。
输入样例1:
在这里给出一组输入。例如:
2000-06-05
2000-06-06
输出样例1:
在这里给出相应的输出。例如:
我们生日相差1天
对不起,我们有缘无份
样例2">输入样例2:
在这里给出一组输入。例如:
2000-06-05
2000-06-07
输出样例2:
在这里给出相应的输出。例如:
我们生日相差2天
傻瓜,我心仪的人其实是你呀!
写的有一点点麻烦了,可以参考着改进一下…
#include<stdio.h>
struct confession{
int year,month,date;
};
int main(){
int number=0;
struct confession s[2];
for(int i=0;i<2;i++){
scanf("%d-%d-%d",&s[i].year,&s[i].month,&s[i].date);
}
if(s[0].year==s[1].year){
//情况一:年1=年2
if(s[0].month==s[1].month){
//1.月相等
number=(s[0].date>s[1].date?s[0].date-s[1].date:s[1].date-s[0].date);
}else{
//2.月不等
if((s[0].year%4==0&&s[0].year%100!=0)||s[0].year%400==0){
//(1)闰年
switch(s[0].month>s[1].month?s[1].month:s[0].month){
case 1:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 2:number=29-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 3:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 4:number=30-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 5:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 6:number=30-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 7:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 8:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 9:number=30-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 10:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 11:number=30-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 12:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
}
//加足月
for(int i=(s[0].month>s[1].month?s[1].month:s[0].month)+1;i<(s[0].month>s[1].month?s[0].month:s[1].month);i++){
switch(i){
case 1:number+=31;break;
case 2:number+=29;break;
case 3:number+=31;break;
case 4:number+=30;break;
case 5:number+=31;break;
case 6:number+=30;break;
case 7:number+=31;break;
case 8:number+=31;break;
case 9:number+=30;break;
case 10:number+=31;break;
case 11:number+=30;break;
case 12:number+=31;break;
}
}
}else{
//(2)平年
switch(s[0].month>s[1].month?s[1].month:s[0].month){
case 1:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 2:number=28-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 3:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 4:number=30-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 5:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 6:number=30-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 7:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 8:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 9:number=30-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 10:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 11:number=30-(s[0].month>s[1].month?s[1].date:s[0].date);break;
case 12:number=31-(s[0].month>s[1].month?s[1].date:s[0].date);break;
}
//加足月
for(int i=(s[0].month>s[1].month?s[1].month:s[0].month)+1;i<(s[0].month>s[1].month?s[0].month:s[1].month);i++){
switch(i){
case 1:number+=31;break;
case 2:number+=28;break;
case 3:number+=31;break;
case 4:number+=30;break;
case 5:number+=31;break;
case 6:number+=30;break;
case 7:number+=31;break;
case 8:number+=31;break;
case 9:number+=30;break;
case 10:number+=31;break;
case 11:number+=30;break;
case 12:number+=31;break;
}
}
}
number+=(s[0].month>s[1].month?s[0].date:s[1].date);
}
}else{
//情况二:年1!=年2
if(((s[0].year>s[1].year?s[1].year:s[0].year)%4==0&&(s[0].year>s[1].year?s[1].year:s[0].year)%100!=0)||(s[0].year>s[1].year?s[1].year:s[0].year)%400==0){
switch(s[0].year>s[1].year?s[1].month:s[0].month){//小年天数
case 1:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 2:number=29-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 3:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 4:number=30-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 5:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 6:number=30-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 7:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 8:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 9:number=30-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 10:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 11:number=30-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 12:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
}
}else{
switch(s[0].year>s[1].year?s[1].month:s[0].month){
case 1:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 2:number=28-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 3:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 4:number=30-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 5:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 6:number=30-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 7:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 8:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 9:number=30-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 10:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 11:number=30-(s[0].year>s[1].year?s[1].date:s[0].date);break;
case 12:number=31-(s[0].year>s[1].year?s[1].date:s[0].date);break;
}
}
for(int i=(s[0].year>s[1].year?s[1].month:s[0].month)+1;i<=12;i++){
if(((s[0].year>s[1].year?s[1].year:s[0].year)%4==0&&(s[0].year>s[1].year?s[1].year:s[0].year)%100!=0)||(s[0].year>s[1].year?s[1].year:s[0].year)%400==0){
switch(i){
case 1:number+=31;break;
case 2:number+=29;break;
case 3:number+=31;break;
case 4:number+=30;break;
case 5:number+=31;break;
case 6:number+=30;break;
case 7:number+=31;break;
case 8:number+=31;break;
case 9:number+=30;break;
case 10:number+=31;break;
case 11:number+=30;break;
case 12:number+=31;break;
}
}else{
switch(i){
case 1:number+=31;break;
case 2:number+=28;break;
case 3:number+=31;break;
case 4:number+=30;break;
case 5:number+=31;break;
case 6:number+=30;break;
case 7:number+=31;break;
case 8:number+=31;break;
case 9:number+=30;break;
case 10:number+=31;break;
case 11:number+=30;break;
case 12:number+=31;break;
}
}
}
for(int i=1;i<(s[0].year>s[1].year?s[0].month:s[1].month);i++){//大年天数
if(((s[0].year>s[1].year?s[0].year:s[1].year)%4==0&&(s[0].year>s[1].year?s[0].year:s[1].year)%100!=0)||(s[0].year>s[1].year?s[0].year:s[1].year)%400==0){
switch(i){
case 1:number+=31;break;
case 2:number+=29;break;
case 3:number+=31;break;
case 4:number+=30;break;
case 5:number+=31;break;
case 6:number+=30;break;
case 7:number+=31;break;
case 8:number+=31;break;
case 9:number+=30;break;
case 10:number+=31;break;
case 11:number+=30;break;
case 12:number+=31;break;
}
}else{
switch(i){
case 1:number+=31;break;
case 2:number+=28;break;
case 3:number+=31;break;
case 4:number+=30;break;
case 5:number+=31;break;
case 6:number+=30;break;
case 7:number+=31;break;
case 8:number+=31;break;
case 9:number+=30;break;
case 10:number+=31;break;
case 11:number+=30;break;
case 12:number+=31;break;
}
}
}
number+=(s[0].year>s[1].year?s[0].date:s[1].date);
for(int i=(s[0].year>s[1].year?s[1].year:s[0].year)+1;i<(s[0].year>s[1].year?s[0].year:s[1].year);i++){//补足中间年份
if((i%4==0&&i%100!=0)||i%400==0){
number+=366;
}else{
number+=365;
}
}
}
if(number%2==1){
printf("我们生日相差%d天\n对不起,我们有缘无份",number);
}else{
printf("我们生日相差%d天\n傻瓜,我心仪的人其实是你呀!",number);
}
return 0;
}