编写一个程序,计算今天是今年的第几天. 例如: 输入年 2022 输入月 4 输入天 17

编程一个程序,计算今天是今年的第几天.
  例如: 输入年 2022 输入月 4  输入天 17

闰年判断标准(满足任何一个)
    1.如果能够被4整除&&但是不能被100整除
    2. 能够被400整除

package lianxi;
import java.util.Scanner;
public class bc02 {
    public static void main(String[] args) {
        Scanner s = new Scanner(System.in);
        System.out.println("输入年");
        int n = s.nextInt();
        int d =0;
        /* 1 3 5 7 8 10 12     31天
     4 6 9 11                30天
      r2   29           p2     28   */
        if((n%4==0&&n%100!=0)||n%400==0)
        {
            System.out.println("输入月");
            int y = s.nextInt();
            System.out.println("输入天");
            int t = s.nextInt();
            if(y==1) d = t;
            if(y==2) d = 31+t;
            if(y==3) d = 31+29+t;
            if(y==4) d = 31*2+29+t;
            if(y==5) d = 31*2+30+29+t;
            if(y==6) d = 31*3+30+29+t;
            if(y==7) d = 31*3+30*2+29+t;
            if(y==8) d = 31*4+30*2+29+t;
            if(y==9) d = 31*5+30*2+29+t;
            if(y==10) d = 31*5+30*3+29+t;
            if(y==11) d = 31*6+30*3+29+t;
            if(y==12) d = 31*6+30*4+29+t;
        }
        else {
            System.out.println("输入月");
            int y = s.nextInt();
            System.out.println("输入天");
            int t = s.nextInt();
            if(y==1) d = t;
            if(y==2) d = 31+t;
            if(y==3) d = 31+28+t;
            if(y==4) d = 31*2+28+t;
            if(y==5) d = 31*2+30+28+t;
            if(y==6) d = 31*3+30+28+t;
            if(y==7) d = 31*3+30*2+28+t;
            if(y==8) d = 31*4+30*2+28+t;
            if(y==9) d = 31*5+30*2+28+t;
            if(y==10) d = 31*5+30*3+28+t;
            if(y==11) d = 31*6+30*3+28+t;
            if(y==12) d = 31*6+30*4+28+t;

        }

        System.out.println(d);
    }
}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 可以使用C语言编写一个程序输入,并判断这一是这一第几天。具体实现方法如下: 1. 首先,需要输入三个变量。 2. 然后,判断输入份是否为闰。如果是闰,则该2份有29,否则只有28。 3. 接着,根据输入份,计算出该份之前的数总和。 4. 最后,将该份之前的数总和加上输入期,即可得到这一是这一第几天。 下面是一个示例代码: ``` #include <stdio.h> int main() { int year, month, day, sum = ; int days[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; // 每个份的数 printf("请输入:\n"); scanf("%d%d%d", &year, &month, &day); // 判断是否为闰 if ((year % 4 == && year % 100 != ) || year % 400 == ) { days[1] = 29; // 闰2份有29 } // 计算份之前的数总和 for (int i = ; i < month - 1; i++) { sum += days[i]; } // 加上输入期,即为这一是这一第几天 sum += day; printf("%d%d%d是这一的第%d。\n", year, month, day, sum); return ; } ``` 运行程序后,输入,即可得到这一是这一第几天。例如,输入2022315程序输出: ``` 2022315是这一的第74。 ``` ### 回答2: C语言是一种广泛使用的编程语言,在计算机编程和软件开发中应用广泛。C语言可以实现很多实用的功能,比如输入,判断这一是这一第几天。这种功能在时间计算历应用中非常实用。 要实现这个功能,需要用到C语言的一些基本知识,如变量、输入输出等。具体实现步骤如下: 1. 首先,定义三个变量year、month、day,用来表示输入。可以使用scanf函数从用户输入中获取这些值,例如: scanf("%d%d%d", &year, &month, &day); 2. 然后,需要判断输入份是否为闰,因为闰的二份有29,其它份都是28或者30。判断闰的方法是:能被4整除但不能被100整除,或者能被400整除的份都是闰。可以使用if语句进行判断,例如: if((year%4==0 && year%100!=0) || year%400==0) { //闰处理 } else { //非闰处理 } 3. 接着,需要计算输入期在这一中的数。可以定义一个变量days来表示数,初始化为输入数。然后,通过循环计算数,例如: for(int i=1; i<month; i++) { if(i==2) { //二份 if(闰) { days += 29; } else { days += 28; } } else if(i==4 || i==6 || i==9 || i==11) { //30份 days += 30; } else { //31份 days += 31; } } 4. 最后,输出计算结果。输出格式可以自己定义,例如: printf("%d%d%d是这一的第%d\n", year, month, day, days); 通过以上步骤,输入,就可以判断这一是这一第几天。这是C语言中常见的时间计算应用之一,也是C语言初学者需要掌握的基本知识之一。 ### 回答3: 题目要求我们输入,然后判断这一是这一第几天。 那么我们可以按照以下步骤来完成这个任务: 1. 首先,我们需要从用户那里获取输入期信息,经过处理,将其存储到变量中。可以使用scanf函数来实现: ``` int year, month, day; printf("请输入期,格式为yyyy-mm-dd:\n"); scanf("%d-%d-%d", &year, &month, &day); ``` 2. 接下来,我们需要判断输入份是否为闰。闰有以下两种情况: a. 能被4整除,但不能被100整除。 b. 能被400整除。 在C语言中可以这样实现: ``` int is_leap_year; if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) { is_leap_year = 1; } else { is_leap_year = 0; } ``` 3. 确定闰后,我们可以计算这一是这一第几天。根据已知的期信息,我们需要计算出到该期为止,共经过了多少。 对于该,我们可以按照以下逻辑计算: a. 如果是1份,该期就是该第几天。 b. 如果是其他份,我们可以按照以下公式计算:该之前所有份的数 + 当数。 对于该份之前的所有数,我们可以使用一个数组来保存,数组下标表示份,数组值表示该份之前所有份的数之和。并且需要注意2份的数,闰和平是不同的。 示例代码: ``` int days_of_month[13] = {0,31,59,90,120,151,181,212,243,273,304,334,365}; if (is_leap_year && month > 2) { days_of_month[2] = 60; } int days = days_of_month[month - 1] + day; ``` 4. 最后,我们需要输出得到的结果: ``` printf("%d%d%d是这一的第%d\n", year, month, day, days); ``` 综上所述,我们可以按照以上步骤来完成该题目的要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CsDn.FF

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值