算法笔记之日期计算(c/c++)

前言

在学习算法程序设计中,总结几个日期计算的函数。这类问题对应于循环和数组的应用有益,也适合于分类讨论的简单学习。数学思想上相当于初中水平,所以也称之为入门。

1. 判断闰年

口诀:==四年一闰则百年不闰,四百年一闰==

bool IsLeap(int n){
    return (n%4==0 && n%100!=0 ||n%400==0);
}

bool类型表示判断真假,后面返回值可以是一个判断式子,相当于if中的返回0,1。同样,bool返回值也可以用于数组下标表示

2.判断日期是该年第几天

算法:循环模拟求和即可

int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
    
int Date(int y,int m,int d){
    if(IsLeap(y))   month[2]=29;
    else            month[2]=28;
    int sum=0;
    for(int i=1;i<=m;i++){
        if(i==m){
            sum+=d;
        }else{
            sum+=month[i];
        }
    }
    return sum;
}

3. 求两个日期相差天数

算法:循环遍历和分类讨论

当日期同年同月,直接日期相减;

当日期同年不同月,则用前面函数计算该日期是该年第几天,两者相减;

当日期不同年,则分成三部分求和:==小年年末差+间隔整年天数+大年第几天天数==

int DateBetw(int y1,int m1,int d1,int y2,int m2,int d2){
    int sum=0;
    if(y1==y2 && m1==m2){
        sum=d2-d1;
    }else if(y1==y2){
        //前面计算日期为该年第几天
        sum=Date(y2,m2,d2)-Date(y1,m1,d1);
    }else{
        //小年年末
        if(IsLeap(y1))  sum+=366-Date(y1,m1,d1);
        else            sum+=365-Date(y1,m1,d1);
        //中间整年间隔
        for(int i=y1+1;i<y2;i++){
            int year;
            if(IsLeap(i))   year=366;
            else            year=365;
            sum+=year;
        }
        //大年第几天
        sum+=Date(y2,m2,d2);
    }
    return sum;

}

4.计算该日期是星期几

算法1:求出该日期和一个已知星期几的日期相差天数,该一直日期要早于题目日期,星期是7天一循环,一次用相差天数对7取余即可

算法2:和上述差不多,只是可以不用要求一直星期的日期早。==若已知星期日期晚于题目日期,差值取负数对7取余再加7即可==

小技巧:公元1年1月1号是星期一,不过一般不用;1900年1月1是星期一,1000年1月1是星期三,这些估计够用

计算星期几(题目链接)

#include<bits/stdc++.h>
typedef long long ll;
using namespace std;

int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};

//判断闰年
bool Isleap(int y){
    return (y%4==0 && y%100!=0 ||y%400==0);
}

//计算该日期是该年的第几天
int dates(int y,int m,int d){
    if(Isleap(y))   month[2]=29;
    else            month[2]=28;
    int sum=0;
    for(int i=1;i<m;i++){
        sum+=month[i];
    }
    sum+=d;
    return sum;
}

//计算日期差值
int datesbetw(int y1,int m1,int d1,int y2,int m2,int d2){
    int sum=0;
    if(y1==y2 && m1==m2){
        sum=d2-d1;
    }else if(y1==y2){
        sum=dates(y2,m2,d2)-dates(y1,m1,d1);
    }else{
        for(int i=y1+1;i<y2;i++){
            int year;
            if(Isleap(i))   year=366;
            else            year=365;
            sum+=year;
        }
        if(Isleap(y1))  sum+=366-dates(y1,m1,d1);
        else            sum+=365-dates(y1,m1,d1);
        sum+=dates(y2,m2,d2);
    }
    return sum;
}

int main(){
    //计算星期几,好的
    int d,y;
    char m[50];
    char Month[12][50]={"January","February","March","April","May","June","July","August","September","October","November","December"};
    while(scanf("%d %s %d",&d,m,&y)!=EOF){
        int y1=y,d1=d,m1;
        for(int i=0;i<12;i++){
            if(strcmp(m,Month[i])==0)
            {
                m1=i+1;break;
            }
        }
        int sum;
        sum=datesbetw(1000,1,1,y1,m1,d1);
        string week[7]={"Wednesday", "Thursday", "Friday", "Saturday", "Sunday", "Monday", "Tuesday"};
        cout<<week[sum%7]<<endl;
    }
    return 0;
}

5. 经过多少天后的日期

算法:和上面的题目很像,一九是要分类讨论和循环,难度不大,注意输出格式。

计算日期(题目链接)

#include<bits/stdc++.h>
typedef long long ll;
using namespace std;


bool Isleap(int y){
    return (y%4==0 && y%100!=0 ||y%400==0);
}
//求过多少天之后的日期

int main(){
    int n;
    cin>>n;
    int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
    while(n--){
        int y,m,d,cnt;
        cin>>y>>m>>d>>cnt;
        while(cnt!=0){
            int year;
            //闰年
            if(Isleap(y)){
                year=366;month[2]=29;
            }
            else{
                year=365;month[2]=28;
            }

            //增加
            if(cnt>=year){
                cnt-=year;
                y++;
            }else if(cnt>=month[m]){
                cnt-=month[m];
                m++;
                if(m>12){
                    m-=12;
                    y++;
                }
            }else{
                d+=cnt;
                cnt=0;
                if(d>month[m]){
                    d-=month[m];
                    m++;
                    if(m>12){
                        m-=12;
                        y++;
                    }
                }
            }
        }
        //计算日期函数
        printf("%d-%02d-%02d\n",y,m,d);
    }
    return 0;
}
  • 5
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 《算法笔记》是由胡凡编写的一本关于算法学习的教材,它最初以C/C++为主要编程语言。这本教材主要面向想要学习算法的初学者,以及希望进一步提升算法能力的人群。 《算法笔记》的内容广泛而且深入,涵盖了很多算法的基础知识和主要思想,如递归、排序、查找、图论、动态规划等。通过学习这本教材,读者可以掌握这些算法的基本原理和实现方法,提高解决实际问题的能力。 该教材有几个特点:首先,它提供了很多例子和习题,帮助读者巩固所学的知识;其次,它介绍了很多常用的数据结构,如数组、链表、栈、队列等,读者可以通过学习这些数据结构更好地理解和应用算法;最后,它还介绍了一些高级主题,如高级数据结构、算法优化等,这些内容对于进一步提升算法水平非常有帮助。 《算法笔记》是一本入门级的教材,因此在阅读时需要一些基本的编程知识和逻辑思维能力。该教材的语言简洁明快,适合作为学习参考书,同时也可以作为算法竞赛的辅助教材。 总而言之,《算法笔记》是一本很好的算法学习教材,它以C/C++为编程语言,全面介绍了算法的基本知识和常用方法,适合想要学习算法的初学者。无论是学术研究还是实际应用,阅读《算法笔记》都能提升算法能力,并为进一步学习和应用算法打下坚实的基础。 ### 回答2: 《算法笔记 胡凡 c/c 快速入门pdf》是一本介绍算法和C/C++编程语言的入门书籍。该书的作者是胡凡,它主要规划了算法的学习路径以及基本的C/C++编程语言。这本书适合初学者快速入门,对于想要系统学习算法和C/C++编程的人来说是一本不错的选择。 这本书的内容非常系统和全面。它以算法和数据结构为基础,包括基本排序、查找、图论等算法的介绍和实践,让读者能够快速掌握这些算法的原理和实现方法。同时,它还介绍了C/C++语言的基础知识和编程技巧,帮助读者理解和运用这些知识。 书中每章都有一些练习题,帮助读者巩固所学的知识。同时,每个章节末尾还提供了一些进阶的题目和参考答案,供读者深入学习和自我检测。这样的设计能够帮助读者更好地理解和掌握所学的内容。 总的来说,《算法笔记 胡凡 c/c 快速入门pdf》是一本很好的算法和C/C++入门书籍。它能够帮助读者快速了解算法和数据结构的基础知识,并学会使用C/C++语言进行编程。无论是对于想要入门算法和C/C++编程的初学者,还是已经有一定基础的读者,这本书都是一个很好的选择。 ### 回答3: 《算法笔记:胡凡C/C++快速入门PDF》是一本很棒的入门算法书籍。这本书主要介绍了常用的数据结构与算法,并通过C/C++语言来实现这些算法。 首先,这本书非常适合算法初学者。它从基础的数据结构开始讲解,如数组、链表、栈和队列,然后逐渐引入更复杂的数据结构,如二叉树、图和堆。此外,书中还介绍了常用的排序和查找算法,如冒泡排序、快速排序、二分查找等。每个算法都配有具体的代码实现和详细的解释,帮助读者理解算法的原理和应用。 其次,这本书的学习资料丰富。书中提供了很多例题和习题,读者可以通过实践来巩固所学的知识。此外,书中还介绍了一些常见的算法优化技巧和设计思路,提供了一些高效解决问题的方法和思考方式。 最后,这本书的编写风格简明易懂。作者通过清晰的语言和简洁的代码,将复杂的算法问题简化为易于理解的部分。不论是对于算法初学者还是对于有一定编程基础的读者,这本书都是一本很好的学习资料。 总而言之,《算法笔记:胡凡C/C++快速入门PDF》是一本很好的入门算法书籍。它适合初学者学习和理解常用的数据结构与算法,通过具体的代码实现和详细的解释帮助读者掌握算法的原理和应用。无论是编程初学者还是有一定基础的读者,都可以从这本书中获得丰富的知识和实践经验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值