Java:输入年,月,日 输出该天为该年的第几天

输入年,月,日 输出该天为该年的第几天

  System.out.println("请输入年份:");
  int year = scan.nextInt();
  int month;
  while(true){
      System.out.println("请输入月份:");
      month = scan.nextInt();
      if(month > 12|| month < 1){
         System.out.println("月份错误,请重试!");
      }else break;
    }
   System.out.println("请输入几号:");
   int day = scan.nextInt();
   boolean leap_year = false;

   //判断闰年
   if((year % 4) == 0){
      leap_year = true;
   if((year % 100) == 0){
     if((year % 400) != 0){
       leap_year = false;
    }}}
   //判断日期是否正确
   boolean bool = false;
   while(!bool){
     switch(month){
       case 1,3,5,7,8,10,12:
           if(day > 31){
           System.out.println("日期不对,请重新输入:");
           day = scan.nextInt();
        }else {
   System.out.print("这一天为" + year +"年的第");
   bool = true;
   }break;
       case 4,6,9,11:
            if(day > 30){
            System.out.println("日期不对,请重新输入:");
            day = scan.nextInt();
        }else {
   System.out.print("这一天为" + year +"年的第");
   bool = true;
   }break;
      case 2:
           if(day > 29 || !leap_year && day > 28){
           System.out.println("日期不对,请重新输入:");
           day = scan.nextInt();
       }else {
  System.out.print("这一天为" + year +"年的第");
  bool = true;
  }break;
  }
  }
  int amount=0;
  int num=0;
  //num加上这个月之前的日数
  switch(month){
   case 11:
    num += 31;
   case 10:
    num += 30;
   case 9:
    num += 31;
   case 8:
    num += 31;
   case 7:
    num += 30;
   case 6:
    num += 31;
   case 5:
    num += 30;
   case 4:
    num += 31;
   case 3:
    if(leap_year){
      num += 29;
    }else {
      num += 28;
    }
   case 2:
    num += 31;
 }
  amount += num;//加上之前月份的日数
  amount += day;//加上本月日数
  System.out.println(amount + "天");
 }
 }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以通过计算输入期与该11之间的天数差来判断是这一第几天。具体步骤如下: 1. 计算该11输入期的天数差,记为days。 2. 判断该是否为闰,如果是,则该的第一天为11,天数为366;否则为365。 3. 该第几天即为days+1。 例如,输入2021315,则计算该期与202111之间的天数差为74天(1有31天,2有28天,3有15天),因此2021的第一天为11,是365天,所以2021的第74+1=75天。 ### 回答2: 要想判断某一第几天,需要先了解一中有多少天。普通份有365天,闰有366天,而闰是指能够被4整除但不能被100整除的份,或者能够同时被100和400整除的份。比如2000是闰,而1900不是闰。 接下来,需要利用输入计算这一天是这一第几天。具体方法如下: 1. 首先判断这一是否是闰,如果是闰,则2份的天数为29天,否则为28天。 2. 接着根据输入份,计算出前几个的天数之和。例如,如果输入的是331,那么1和2的天数之和为31+28=59天。 3. 最后,再加上输入期,就是这一第几天。例如,331是这一的第90天。 综上所述,判断某一第几天需要根据输入进行计算,先判断闰还是普通,再计算前几个份的天数之和,最后加上输入期即可。 ### 回答3: 题目分析: 输入一个期,需要判断这一天属于这一第几天。计算某一第几天需要考虑这一是否为闰,以及该天所处的份和期。 步骤: 1. 判断输入份是否为闰。 2. 根据输入份和期,计算该天属于该第几天。 3. 输出计算结果。 代码实现: 输入,将分别分离,设变量y表示份,m表示份,d表示期。判断y是否为闰,若是闰,则二有29天;否则二只有28天。然后根据输入份m计算前m-1个份的天数之和,再加上d天,即为所求结果。 具体代码如下: ``` #include<iostream> #include<cmath> using namespace std; // 判断闰函数 bool isLeapYear(int year) { if(year % 4 == 0 && year % 100 != 0 || year % 400 == 0) return true; else return false; } int main() { int year, month, day, days = 0; cout << "请输入,用空格隔开:" << endl; cin >> year >> month >> day; // 判断是否为闰 if(isLeapYear(year) && month > 2) days++; // 计算前m-1个的天数之和 int monthDays[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; for(int i = 1; i < month; i++) days += monthDays[i]; // 加上当期 days += day; // 输出计算结果 cout << year << "" << month << "" << day << "是" << year << "的第" << days << "天。" << endl; return 0; } ``` 总结: 本题是一个比较简单的期计算问题,需要考虑的主要是闰的问题,以及每个的天数不同,需要特别注意。计算时可以使用一个数组储存每个的天数,然后循环累加即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值