2.输入某年某月某日,判断这一天是这一年的第几天?

本文介绍两种方法来计算给定日期是一年中的第几天,包括非闰年和闰年的处理方式。通过使用C语言的switch-case结构,实现了一个简单的用户交互程序,能够根据输入的年月日准确计算出该日期在这一年的具体位置。

题目:输入某年某月某日,判断这一天是这一年的第几天?
方法一:
#include<stdio.h>
void main()
{
int year,month,daily,sum;
while(1)
{
printf("请输入年月日:/n");
scanf("%d%d%d",&year,&month,&daily);
switch(month)
{
case 1:{sum=daily;break;}
case 2:{sum=31+daily;break;}
case 3:{sum=31+28+daily;break;}
case 4:{sum=31+28+31+daily;break;}
case 5:{sum=31+28+31+30+daily;break;}
case 6:{sum=31+28+31+30+31+daily;break;}
case 7:{sum=31+28+31+30+31+30+daily;break;}
case 8:{sum=31+28+31+30+31+30+31+daily;break;}
case 9:{sum=31+28+31+30+31+30+31+31+daily;break;}
case 10:{sum=31+28+31+30+31+30+31+31+30+daily;break;}
case 11:{sum=31+28+31+30+31+30+31+31+30+31+daily;break;}
case 12:{sum=31+28+31+30+31+30+31+31+30+31+30+daily;break;}
default:{printf("你输入的月份不对,请重新输入。/n");};
}
if((year%400==0||(year%4==0 && year%100!=0) ) &&month>=2)
printf("你输入的日子是%d年的第%d天。/n",year,sum+1);
else
printf("你输入的日子是%d年的第%d天。/n",year,sum);

}

}

 

方法二:
main()
{
int day,month,year,sum,leap;
printf("/nplease input year,month,day/n");
scanf("%d,%d,%d",&year,&month,&day);
switch(month)/*先计算某月以前月份的总天数*/
{
  case 1:sum=0;break;
  case 2:sum=31;break;
  case 3:sum=59;break;
  case 4:sum=90;break;
  case 5:sum=120;break;
  case 6:sum=151;break;
  case 7:sum=181;break;
  case 8:sum=212;break;
  case 9:sum=243;break;
  case 10:sum=273;break;
  case 11:sum=304;break;
  case 12:sum=334;break;
  default:printf("data error");break;
}
sum=sum+day;  /*再加上某天的天数*/
  if(year%400==0||(year%4==0&&year%100!=0))/*判断是不是闰年*/
   leap=1;
  else
   leap=0;
if(leap==1&&month>2)/*如果是闰年且月份大于2,总天数应该加一天*/
sum++;
printf("It is the %dth day.",sum);}

判断输入某年某月某日是该年的第几天,需要考虑不同月份的天数以及闰年的影响。以下是几种不同编程语言的实现示例: ### C语言实现 ```c #include <stdio.h> int main() { int y, m, d; printf("input y,m,d:"); scanf("%d%d%d", &y, &m, &d); switch (m) { case 12: d += 30; case 11: d += 31; case 10: d += 30; case 9: d += 31; case 8: d += 31; case 7: d += 30; case 6: d += 31; case 5: d += 30; case 4: d += 31; case 3: d += 28; case 2: d += 31; } if (m > 2 && (y % 400 == 0 || (y % 4 == 0 && y % 100 != 0))) { d++; } printf("是%d年的第%d天", y, d); return 0; } ``` 该C语言代码的逻辑是,先根据输入的月份,按照平年的情况累加前面月份的天数。然后判断输入的月份是否大于2月,并且该年是否为闰年,如果是闰年则天数加1 [^2]。 ### Python实现 ```python def is_leap_year(year): return (year % 400 == 0) or (year % 4 == 0 and year % 100 != 0) def day_of_year(year, month, day): days_in_month = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31] if is_leap_year(year): days_in_month[1] = 29 total_days = 0 for i in range(month - 1): total_days += days_in_month[i] total_days += day return total_days year, month, day = map(int, input("请输入年、月、日,用空格分隔: ").split()) print(f"是{year}年的第{day_of_year(year, month, day)}天") ``` Python代码中,首先定义了一个判断闰年的函数`is_leap_year`。然后定义`day_of_year`函数,根据是否为闰年修改2月的天数,再累加前面月份的天数和当前日期,得到该天是该年的第几天。 ### Java实现 ```java import java.util.Scanner; public class DayOfYear { public static boolean isLeapYear(int year) { return (year % 400 == 0) || (year % 4 == 0 && year % 100 != 0); } public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.print("请输入年、月、日,用空格分隔: "); int year = scanner.nextInt(); int month = scanner.nextInt(); int day = scanner.nextInt(); int[] daysInMonth = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; if (isLeapYear(year)) { daysInMonth[1] = 29; } int totalDays = 0; for (int i = 0; i < month - 1; i++) { totalDays += daysInMonth[i]; } totalDays += day; System.out.printf("是%d年的第%d天", year, totalDays); scanner.close(); } } ``` Java代码的实现思路与Python类似,先定义判断闰年的函数`isLeapYear`,在`main`方法中根据是否为闰年修改2月的天数,然后累加前面月份的天数和当前日期,输出该天是该年的第几天
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值