• 当前日期日期hdu 2133 What day is itjava教程


    新手发帖,很多方面都是刚入门,有错误的地方请大家见谅,欢迎批评指正

        理处日期

        盘算天数时,0001年1月1日,是366天,要减去前边算的0年的365天

        每日一道理
    有一首诗最为动人,那就是青春;有一段人生最美丽,那就是青春;有一道风景最为亮丽,那就是青春。青春,不要说已疲惫,也许你的幻想曾被现实无情毁灭,也许你的追求毫无结果,但你应该相信,没有寒风的洗礼,哪来万紫千红的春天,没有心的耕耘,哪有累累硕果?
    #include<stdio.h>
    int days[12]={31,28,31,30,31,30,31,31,30,31,30,31};
    char s[7][10]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};
    struct date
    {
        int year,month,day;
    };
    int leap(int year)
    {
        return (year%4==0&&year%100!=0)||year%400==0;
    }
    int date2int(date a)//求当前日期到公元1年,1月,0日的天数
    {
        int ret=a.year*365+(a.year-1)/4-(a.year-1)/100+(a.year-1)/400,i;
        days[1]+=leap(a.year);
        for(i=0;i<a.month-1;ret+=days[i++]);
        days[1]=28;
        return ret+a.day;
    }
    int judge(date b)
    {
        if(b.month<=0||b.month>12)
            return 0;
        if(b.month==2)
            return b.day>0&&b.day<=28+leap(b.year);
        return b.day>0&&b.day<=days[b.month-1];
    }
    int main()
    {
        date a,b;
        int i,n,m;
        while(scanf("%d%d%d",&a.year,&a.month,&a.day)!=-1)
        {
            if(judge(a)==0)
            {puts("illegal");continue;}
            m=date2int(a)-365;//盘算的时候加上了0年的天数,所以要减去
            //printf("%d\n",m);
            m=m%7;
            puts(s[m]);
        }
    return 0;
    }

        
     

    文章结束给大家分享下程序员的一些笑话语录: 现在社会太数字化了,所以最好是有一个集很多功能于一身的设备!

  • 相关阅读:
    hdu 3006 The Number of set(思维+壮压DP)
    Mysql-SQL优化-统计某种类型的个数
    canvas.clipPath canvas.clipRect() 无效的原因
    linux下alias命令具体解释
    使用带粒子效果的 CAEmitterLayer
    Wordpress 建站(一)
    一个有趣的问题:ls -l显示的内容中total究竟是什么?
    (转)奇妙的数据挖掘
    android几个高速打包命令
    hdu3336解读KMP算法的next数组
  • 原文地址:https://www.cnblogs.com/xinyuyuanm/p/3042253.html
Copyright © 2020-2023  润新知