美文网首页
2018-06-10 机试准备02

2018-06-10 机试准备02

作者: Huxx499 | 来源:发表于2018-06-10 17:12 被阅读0次

日期类:


一、例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

    日期类: 一、例2.3 求两个日期间的天数差;区间问题:统一区间 自己的写法 思路/错误: 1)统一到0000年0...

  • 【85】蝶舞,在挣扎后

    2018-06-10 星期日 小雨 少年自有少年狂,藐昆仑,笑吕梁,磨剑十年,今将试锋芒。 ...

  • 机试

    package com.example.js; import android.app.Activity; impo...

  • 2018-06-09 机试准备01

    今天开始正式日常做机试训练(参考书:计算机考研--机试指南)记录一些问题/解决办法/知识回顾/易错点/心得之类的。...

  • 2018-06-13 机试准备03

    Hash值的应用 将存储位置与数据本身对于起来的存储手段 一、例2.5 统计同成绩学生人数 在已知该例可以用Has...

  • 2018-06-13 机试准备04

    排版题 一、例2.7 输出梯形 该规律顺序与输出顺序一致,可以从上至下、从左至右应用规律。 二、例2.8 叠筐 图...

  • 2018-06-17 机试准备07

    数据结构 二、哈夫曼树(栈部分还没做完) 定义: 给定n个结点和它们的权值,以它们为叶子节点构造一棵带权路径长度和...

  • 2018-06-17 机试准备08

    数据结构 三、二叉树 遍历:前序(中左右)、中序(左中右)、后序(左右中)--------递归实现 一、例3.4 ...

  • 2018-06-14 机试准备05

    查找 一、例2.9 找x 此题很简单 线性遍历数组查找 O(m) 只是为了回忆该题型 发现自己写的和参考实例不同的...

  • 2018-06-14 机试准备06

    贪心算法 一、例2.11 FatMouse'Trade 比较简单的贪心算法 但是太久没写还是绕了一会儿 其实主要是...

网友评论

      本文标题:2018-06-10 机试准备02

      本文链接:https://www.haomeiwen.com/subject/clifeftx.html