基础测试编程题:
小明从2006年1月1日开始,每三天结识一个美女两天结识一个帅哥,编程实现当输入2006年1月1日之后的任意一天,输出小明那天是结识美女还是帅哥。
我的原代码:
小明从2006年1月1日开始,每三天结识一个美女两天结识一个帅哥,编程实现当输入2006年1月1日之后的任意一天,输出小明那天是结识美女还是帅哥
*/
#include <stdio.h>
int main(){
int n, y, r, day = 0, i;
scanf("%d年%d月%d日", &n, &y, &r);
day += (n - 2006) * 365 + (n - 2005) / 4;//一年一年加日子,有中间有几个闰年多加今天
for (i = 1; i < y; i++){//通过循环一个月一个月加日子
switch (i){
case 1:
case 3:
case 5:
case 7:
case 8:
case 10:
day += 31;
break;
case 4:
case 6:
case 9:
case 11:
day += 30;
break;
case 2:
if (n % 4 == 0)//判断闰年二月
day += 29;
else
day += 28;
break;
}
}
day += r;//一天一天加日子
if (day % 2 == 0){//两天一帅哥
printf("帅哥 ");
}
if (day % 3 == 0){//三天一美女
printf("美女 ");
}
printf("\n");
return 0;
}
这本身不是一道难题,但是是一道比较复杂,考验耐心和细心的题。
重点是要计算闰年,整一年的闰年是十分好解决的,多出的几个月里的日子计算需要耐心和细心。在考虑和计算的时候一定要小心多加一个月或者少加一个月,具体实现我是用过用循环一个一个月累加日子,避免计算错误。别的其实没什么大问题,细心就好了。