日历问题

经典编程题目解答1

1.年月日问题

#include<iostream>
#include<math.h>
#include<stdlib.h>
#include<iomanip>
using namespace std;


int days;
int get_dayofweek();
int get_year();
int get_month(int leap_year);



int main(){
//bool flag;//false for bike and true for walk;
int year,month,dayofweek;
int leap_year;
char week[7][10]={"Saturday","Sunday","Monday","Tuesday","Wednesday","Thursday","Friday"};
while((cin>>days)&&days!=-1){
 dayofweek=get_dayofweek();
 year=get_year();
 leap_year=(year%4==0&&year%100!=0||year%400==0);
 month=get_month(leap_year);

 cout<<year<<'-';
 if(month<10){
    cout<<'0';
 }
 cout<<month<<'-';
 if(days<9){
    cout<<'0';
 }
 cout<<++days<<' ';
 cout<<week[dayofweek];
 cout<<endl;
}



return 0;

}
//cout<<fixed<<setprecision(2) << f

//有覆盖掉其他数值的可能性。

int get_dayofweek(){

int dayofweek;
dayofweek=days%7;
return dayofweek;

}

int get_year(){
int i=2000,leap_year;

while(1){
    leap_year=(i%4==0&&i%100!=0||i%400==0);
    if(days>=366&&leap_year==1){
    days-=366;
    i++;
    continue;
}
if(days>=365&&leap_year==0){
    days-=365;
    i++;
    continue;
}else

break;

}

return i;

}



int get_month(int leap_year){
int pmonth[12]={31,28,31,30,31,30,31,31,30,31,30,31};
int rmonth[12]={31,29,31,30,31,30,31,31,30,31,30,31};
int j=0;
while(1){
    if(leap_year==1&&days>=rmonth[j]){
        days=days-rmonth[j];
        j++;
    }else if(leap_year==0&&days>=pmonth[j]){
        days=days-pmonth[j];
        j++;
    }else break;



}

return ++j;
}
非常经典的一道题,可以细心替换一下。

另外一道相关的日历题目则是这道。

编程题#4:Tomorrow never knows?
来源: POJ (Coursera声明:在POJ上完成的习题将不会计入Coursera的最后成绩。)

注意: 总时间限制: 1000ms 内存限制: 65536kB

描述
甲壳虫的《A day in the life》和《Tomorrow never knows》脍炙人口,如果告诉你a day in the life,真的会是tomorrow never knows?相信学了计概之后这个不会是难题,现在就来实现吧。

读入一个格式为yyyy-mm-dd的日期(即年-月-日),输出这个日期下一天的日期。可以假定输入的日期不早于1600-01-01,也不晚于2999-12-30。

输入
输入仅一行,格式为yyyy-mm-dd的日期。

输出
输出也仅一行,格式为yyyy-mm-dd的日期

样例输入

样例输出

#include<iostream>
#include<math.h>
#include<stdlib.h>
#include<iomanip>
using namespace std;

int pmonth[12]={31,28,31,30,31,30,31,31,30,31,30,31};
int rmonth[12]={31,29,31,30,31,30,31,31,30,31,30,31};


bool isEndDay(int day,int month,bool leap_year){
  if(leap_year){
    if(day+1>rmonth[month-1]){
        return true;
    }else
        return false;
  }else if(!leap_year){
    if(day+1>pmonth[month-1]){
        return true;
    }else
        return false;
  }

}
bool isEndMonth(int month){

if(month==12){

  return true;
}else
  return false;

}
bool isLeapYear(int year){
if(year % 4 == 0 && year % 100 != 0 || year % 400 == 0){

    return true;
}else
    return false;


}


int main(){
//bool flag;//false for bike and true for walk;
int year,month,day;
char dash;
cin>>year>>dash>>month>>dash>>day;
bool leap_year=isLeapYear(year);
bool end_month=isEndMonth(month);
bool end_day=isEndDay(day,month,leap_year);

if(leap_year){
    if(end_month){
        if(end_day){
            year++;
            month=1;
            day=1;
        }else
        day++;
    }else if(end_day){
        month++;
        day=1;
    }else
     day++;
}else if(!leap_year){
    if(end_month){
        if(end_day){
            year++;
            month=1;
            day=1;
        }else
        day++;
    }else if(day+1>pmonth[month-1]){
        month++;
        day=1;
    }else
     day++;
}


cout << year << "-" <<setw(2)<<setfill('0')<< month << "-" <<setw(2)<<setfill('0')<< day <<endl;
return 0;

}

这个告诉了我if…else和if…if是不一样的。用的时候得小心。这里还提到了两个有趣的格式化输出函数:setfill和setw
有兴趣可以看一下他们的用法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 C 语言中,实现一个日历显示程序是一种常见的练手项目。日历显示程序可以按照指定格式输出一个月份的日历,包括该月的所有日期和星期几。下面是一些可能出现的问题描述: 1. 输出的日历格式不正确,日期或星期几的位置偏移了。 2. 月份或年份输入错误,程序崩溃或输出错误的日历。 3. 输入的月份大于 12 或小于 1,程序崩溃或输出错误信息。 4. 程序无法处理闰年的情况,导致输出的日历不正确。 5. 输出的日历中没有标注出节假日,例如国庆节、春节等。 6. 日历的界面不美观或不易于阅读,例如字体太小、排版太紧等。 这些问题可以通过编写正确的代码和进行测试来解决。对于第一种问题,可以通过仔细检查代码中的循环和条件语句,确保输出的日期和星期几的位置正确。对于第二种问题,程序应该添加输入检查,确保输入的月份和年份在有效范围内。对于第三种问题,程序应该在输入检查中处理不合法的月份,例如输出错误信息或提示用户重新输入。对于第四种问题,程序可以使用闰年判断算法,例如判断该年份是否为 4 的倍数且不为 100 的倍数,或者是否为 400 的倍数。对于第五种问题,程序可以添加节假日的信息表或算法,根据日期输出相应的节假日信息。对于第六种问题,程序可以使用合适的字体和排版方式,确保日历界面美观易读。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值