2018-06-10 机试准备02

日期类:


一、例2.3 求两个日期间的天数差;区间问题:统一区间

自己的写法 思路/错误:

1)统一到0000年01月01日,分别计算相差天数,再相减+1;在读取输入的字符串时用的gets() 但无法使用string类的substr方法提取部分字符串,进而无法用atof转换为数值型

2)参考书上给的示例,发现读取时可以直接用%4d%2d%2d来读取特定位数的数字;1)中计算year1和year2之前的年份天数时有误,只判断year1或year2是不是闰年,未计算之前的年份;2)中没有考虑相差天数的正负问题,应在计算中加ABS绝对值;3)表示平常年份和闰年的两组天数应为days[13][2], 其中0月有0天{0,0}

3)重新统一区间,统一到更小年份如year1的year10101,计算更简便;增加islonger()函数和ABS()函数;判断闰年出错(x%100!=0&&x&4==0||x%400=0?1:0)

参考示例 精妙之处:

1)定义一个宏来判断是否是闰年 #define ISYEAP(x) x%100!=0&&x%4==0||x$400==0?1:0

2)根据普通年和闰年2月天数区分 定义一个二维数组 存储每月天数的数组 dayOfMonth[13][2]

3) 使用三维数组,用年、月、日分别表示数组下标,buf[5001][13][32], 定义为全局变量,以免内存不足

4)输入格式巧妙%4d%2d%2d

5) 以00000101为原点时间,预处理所有日期(0000-5000)与原点日期之间的天数差并保存,当控制台真正输入数据时,只需要O(1)的时间复杂度将保存的数据做差值处理即可,空间换时间。

6)直接用dayOfMonth[Month][ISYEAR(Year)]来调用每月天数,注意ISYEAR()的bool值正好与0/1对应

7)定义一个Date结构 和 结构内的nextDay()方法 循环计算天数!


二、例2.4  输入日期,输出该日期为星期几

自己的写法 思路/错误:

1)写两个struct结构数组,将month.name和month.num;week.name和week.num对应起来;复习了结构数组的初始化 (其实和普通数组一样 {{},{},...{}}; 不懂为什么书上可以直接换行表示不用{} 是版本问题吗?

2)以今天日期的星期数为参照(2018.6.10 星期天)计算任一天与今天的相差天数 再%7;若为正数 则直接可对应;若为负数,则需+7再对应;其中Sunday在正数时为0 在负数时为7 故week结构中赋值有两个Sunday

3)给字符串变量赋值用到了strcpy(str1,str2) 将str2赋值给str1 不能直接用=

4)主要的错误集中在:stack overflow 在buf的定义中以为只要1000-3000的year就可以定义为2001了 然而实际上最大的还是buf[3000] 所以如果要减小空间 需要buf[i-1000] 但是为了可读性和简便 就没有那么做了; 此外 注意strcmp函数=0时是相等 不要弄反了

5)关于string和string.h:string.h是C的头文件,包括strcpy/strcat等字符串处理函数;string是C++的标准头文件,包括string类和C中的string.h

参考示例 学习之处:

1)对于month.name和month.num以及week.name和week.num的处理没有用到struct结构数组,而只用普通数组,月名可以与下标对应,更简单!即monthname[num]=name

2) 在比较输入的字符串和初始化的月名的循环中,用到了break,可以减少循环次数

3)对于间隔天数正负的处理:没有像我一样分开处理,而是统一用(interval%7+7)%7 也可以达到效果,更简便

4)输出字符串用到了puts,比较一下puts和printf的区别:puts相当于printf("%s\n",s)

你可能感兴趣的:(2018-06-10 机试准备02)