星期中的一天——日期问题

文章讲解了如何用C++编写程序,基于格里高利历法规则,计算并确定任意给定日期是一周中的哪一天。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

描述:

我们现在在俄罗斯使用格里高利风格的约会方式。闰年是指数字可被4整除但不能被100整除或可被400整除的年份。例如,2004年、2180年和2400年是闰年。2005年、2181年和2300年都不是闰年。你的任务是编写一个程序,利用今天关于约会的协议,计算最近的过去或未来给定日期对应的一周中的哪一天。

输入描述:

有一行包含日编号d、月名称M和年编号y(1000≤y≤3000)。月份名称是从大写字母开始的相应英文名称。

输出描述:

输出一行,其中包含与日期对应的星期几的英文名称,从大写字母开始。所有其他字母都必须小写。输入/输出中的月和周名称:anuary, February, March, April, May, June, July, August, September, October, November, December ;Sunday, Monday, Tuesday, Wednesday, Thursday, Friday, Saturday

解题思路:

(1)先计算之前年的总天数,再加上该年的天数,最后取余7;

代码:

#include <iostream>
#include <string>
#include <cstdio>
using namespace std;

string months[13]={"","January"," February","March","April","May","June","July","August","September","October","November","December"}; //定义月份数组

string weeks[8]={"","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"}; //定义星期几数组

int monthnum[2][13]={ //定义月份天数数组
    {0,31,28,31,30,31,30,31,31,30,31,30,31}, //非闰年
    {0,31,29,31,30,31,30,31,31,30,31,30,31}  //闰年
};

bool isryear(int year){  //判断是否是闰年
    if(year%100!=0&&year%4==0||year%400==0){
        return true;
    }else{
        return false;
    }
}

int yearnum(int year){  //计算年的天数
    int sum=0;
    for(int i=1;i<year;i++){  //年的天数
        if(isryear(i)){ //是闰年
            sum+=366;
        }else{
            sum+=365;
        }
    }
    return sum;
}
 
int month_day(int year,int month,int day){ //计算月的天数
    int count=isryear(year);//判断该年是否是闰年
    int sum=0;
    for(int i=0;i<month;i++){
        sum+=monthnum[count][i];
    }
    sum+=day;
    return sum;
}

int main() {
    int day,year,month;
    string inmonth;
    while (cin>>day>>inmonth>>year) {
        for(int i=0;i<13;i++){  //把字符转为数字
            if(months[i]==inmonth){
                month=i;
                break;
            }
        }
        int number1=yearnum(year); //之前年的总天数
        int number2=month_day(year, month,day); //该年的天数
        int result=(number1+number2)%7; //取余7
        if(result!=0){ //余数不等于零
            cout<< weeks[result]<<endl;
        }else { //余数等于零
            cout<<weeks[7]<<endl;
        }
    }
}

PS:参考某大佬的思想

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值