DS博客做业01--日期抽象数据类型设计与实现

1.思惟导图及学习体会

1.1第一章绪论知识点思惟导图

1.2 学习体会

比较大的一个感触是C++在一些项目上面确实是比C更加好用的,毕竟c更接近于机器语言。
经过此次大做业的学习,对数据结构大体有了一些了解,对于抽象数据类型的结构的两个特整:数据抽象和数据封装,也有了更好的领悟。

2.大做业做业内容

2.1 设计日期的ADT类型

ADT Date{
数据对象:
    D = {year,month,day | year,month,day属于int类型}
数据关系:
    R = {<year,month>,<month,day>}
数据操做:
    Status InitDate(Date &date, int year, int month, int day);
    //初始化日期
    //操做结果:构造了年月日为year, month, day 的Date

    string OutDate(Date date);
    //初始条件:date存在
    //操做结果:将日期以XXXX-XX-XX的string类型返回

    Status IsLeap(Date date);
    //初始条件:date存在
    //操做结果:是闰年返回TRUE。不是返回FALSE

    string WhichDay(Date date);
    //初始条件:date存在
    //操做结果:返回 string 类型的"是星期一", "是星期二"......

    string WhichMonth(Date date);
    //初始条件:date存在
    //操做结果:返回string类型的月份英文名

    Date AddDays(Date date, int days);
    //初始条件:date存在
    //操做结果:返回当前日期增长days天的日期

    char Relation(Date date, Date otherDate);
    //初始结果:date存在,otherDate存在
    //操做结果:返回 '>' '<' 或 '='

}ADT Date

2.2.数据抽象:

2.3数据封装说明

(1)构造日期函数

作法:动态申请内存,将year,month,day存入date中
html

(2)返回string类型日期函数

作法:将数字型数据利用函数转化到temp1,而后拼接起来
数据结构

(3)判断闰年函数

作法:很基础的题,,就很少说了,,,
函数

(4)判断星期几函数

作法:利用基姆拉尔森计算日期公式计算出星期几,而后将对应的字符串返回就行了
学习

(5)返回月份英文名函数

作法:过程很简单,看图就明白了
网站

(6)返回当前日期增长days天的日期函数

作法:先将每月的不一样天数存储起来,将天数加在resultDate[2]也就是天数上,这时的天数可能超出了。而后利用while循环将天数与本月的最大天数进行动态比较,超了就进一。值得一提的是,当年份发生了改变时要对该年的2月份天数从新判断,不然会出错
设计

(7)比较当前日期与otherDate的逻辑关系函数

作法:转化成整型数直接比较
3d

(8)主函数文件操做部分

3.结果展现

input.txt 文件

输入界面

output.txt 文件

4.调试碰到问题

Q:C++不是很了解?调试

A:经学长推荐了一个”菜鸟教程“的网站,感受很好用,文末附上连接code

Q:将整型数转化成string类型时,因为不了解这个类型于是不知道怎么转化?htm

A:经过百度在CSDN上找到了一个函数能直接转化

菜鸟教程:http://www.runoob.com/cplusplus/cpp-tutorial.html

相关文章
相关标签/搜索