7-138 昨天

7-138 昨天

分数 10

全屏浏览题目

切换布局

作者 黄龙军

单位 绍兴文理学院

小明喜欢上了日期的计算。这次他要做的是日期的减1天操作,即求在输入日期的基础上减去1天后的结果日期。
例如:日期为2019-10-01,减去1天,则结果日期为2019-09-30。

输入格式:

首先输入一个正整数T,表示测试数据的组数,然后是T组测试数据。每组测试输入1个日期,日期形式为“yyyy-mm-dd”。保证输入的日期合法,而且输入的日期和计算结果都在[1000-01-01,9999-12-31]范围内。

输出格式:

对于每组测试,在一行上以“yyyy-mm-dd”的形式输出结果。

输入样例:

1
2019-10-01

输出样例:

2019-09-30
#include <stdio.h>
int main(){
    int arr[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
    int n;
    int month,day,year;
    scanf("%d",&n);
    for(int i = 1;i <= n; i++){
        scanf("%d-%d-%d",&year,&month,&day);
        
        if(year%400==0 || (year%4==0)&&(year%100!=0)){
            
            if(month == 03 && day == 01){
                printf("%d-%02d-%02d\n",year,month-1,29);
            }
            else if(month != 01 && day == 01){
                month -=1;
                day = arr[month];
                printf("%d-%02d-%02d\n",year,month,day);
            }else if(month == 01 && day ==01){
                month =12;
                day = arr[month];
                printf("%d-%02d-%02d\n",year-1,month,day);
            }else{
                printf("%d-%02d-%02d\n",year,month,day-1);
            }
        }else{
            
            if(day == 01 && month != 01){
            month -= 1;
            
            day = arr[month];
            printf("%d-%02d-%02d\n",year,month,day);
        }else if(month == 01 && day == 01){
            
            year -= 1;
            month = 12;
            day = arr[month];
        
            printf("%d-%02d-%02d\n",year,month,day);
        }else{
                printf("%d-%02d-%02d\n",year,month,day-1);
            }
        }
    }
    return 0;
}

 - 此题目我的做法:先定义一个数组,把每个月最后一天放进去,然后输入年月日,然后分别对年月日进行判断,判断可以分别为闰年和非闰年

 - 如果是闰年 

1.那么将3月的01号的前一天改成29号 

2.  1月1号,那么就要将年减掉一位

3.  2月1日 ,那么就把月减一位  减了后把数组里对应1月的拿出来赋值给day

4.  其他的就直接把day减一位就好

  

 - 如果不是闰年那么可以分为三个部分 1.   1月1号,那么就要将年减掉一位

2.  2月1日 ,那么就把月减一位  减了后把数组里对应1月的拿出来赋值给day

3.  其他的就直接把day减一位就好

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小羊 : )

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

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

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

打赏作者

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

抵扣说明:

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

余额充值