2015年天勤考研机试模拟赛解题报告
上传者:宋明权|上传时间:2015-05-09|密次下载
2015年天勤考研机试模拟赛解题报告
2015年天勤考研机试模拟赛解题报告
A: 判断三角形
这题可以用map建立单词与数字之间的映射,也可以用if...else来写。唯一可能成为坑的是前几个单词可能是zero。
代码:http://wendang.chazidian.com/10616118/
#include <cstdio>
#include <cstring>
intstrToNum(char str[]) {
if(strcmp(str, "zero") == 0) return 0;
if(strcmp(str, "one") == 0) return 1;
if(strcmp(str, "two") == 0) return 2;
if(strcmp(str, "three") == 0) return 3;
if(strcmp(str, "four") == 0) return 4;
if(strcmp(str, "five") == 0) return 5;
if(strcmp(str, "six") == 0) return 6;
if(strcmp(str, "seven") == 0) return 7;
if(strcmp(str, "eight") == 0) return 8;
if(strcmp(str, "nine") == 0) return 9;
}
int main() {
int n, len[3] = {0};
char c, str[10];
for(inti = 0; i< 3; i++) {
scanf("%d", &n);
for(int j = 0; j < n; j++) {
scanf("%s", str);
len[i] = len[i] * 10 + strToNum(str);
}
}
if(len[0] + len[1] >len[2] &&
len[0] + len[2] >len[1] &&
len[1] + len[2] >len[0]) {
printf("YES\n");
} else printf("NO\n");
return 0;
}
B: 删除结点
此题为15年408数据结构大题第一题(算法设计题),仿照PAT出题风格而出,所有的坑都是仿照PAT的题目而设计。坑点有:
(1) 虽然结点的Address地址不会是-1,但是第一个结点的地址可能是-1,由此可能导致部
分代码输出超限或者运行超时或者运行错误。(这是PAT中题目的坑点之一)
(2) 可能有不在单链表上的结点,也就是无效结点。这可能导致答案错误。(这也是PAT中
题目的坑点之一)
代码:http://wendang.chazidian.com/10616121/
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
constintmaxn = 100005;
constint TABLE = 1000010;
struct Node { //定义静态链表(第一步)
int address, data, next;
int order; //结点在链表上的序号,无效结点记为maxn
}node[maxn];
boolisExist[TABLE] = {false};
boolcmp(Node a, Node b) {
returna.order<b.order;
}
int main() {
memset(isExist, false, sizeof(isExist));
for(inti = 0; i<maxn; i++) { //初始化(第二步)
node[i].order = maxn;
}
int n, begin, address;
scanf("%d%d", &n, &begin);
for(inti = 0; i< n; i++) {
scanf("%d", &address);
scanf("%d%d", &node[address].data, &node[address].next);
node[address].address = address;
}
int count = 0, p = begin;
while(p != -1) { //枚举链表,计数有效结点个数(第三步)
if(!isExist[abs(node[p].data)]){
isExist[abs(node[p].data)] = true;
node[p].order = count++;
}
p = node[p].next;
}
if(count == 0) { //特判,新链表中没有结点时输出0 -1
printf("0 -1\n");
} else {
sort(node, node + maxn, cmp); //筛选有效结点,并按结点顺序排序(第四步) //输出结果(第五步)
printf("%d %05d\n", count, node[0].address); //防止-1被%05d化,因此提前判断 for(inti = 0; i< count; i++) {
if (i != count - 1) {
printf("%05d %d %05d\n", node[i].address, node[i].data, node[i+1].address); } else {
printf("%05d %d -1\n", node[i].address, node[i].data);
}
}
}
return 0;
}
C: 收集数码晶体
此题为15年408数据结构大题第二题。本题其实是求这样一个问题:求从起点S到终点T的长度为L的路径条数,而这恰好就是邻接矩阵的L次幂。注意在求幂时也要时刻模上1000000007,否则可能爆long long使结果变成负数。
本题用DFS/BFS会超时,复杂度爆棚了。
代码:http://wendang.chazidian.com/10616125/
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
constintmaxn = 60;
const long long MOD = 1000000007;
longlong G[maxn][maxn], ans[maxn][maxn], temp[maxn][maxn];
voidMatrixPow(int n, int L) {
for(int times = 0; times < L; times++) {
for(inti = 0; i< n; i++) {
for(int j = 0; j < n; j++) {
temp[i][j] = 0;
for(int k = 0; k < n; k++) {
temp[i][j] = (temp[i][j] + (ans[i][k] * G[k][j] % MOD + MOD)) % MOD;
}
}
}
for(inti = 0; i< n; i++) {
for(int j = 0; j < n; j++) {
ans[i][j] = temp[i][j];
}
}
}
}
voidinit() {
memset(G, 0, sizeof(G));
memset(ans, 0, sizeof(ans));
for(inti = 0; i<maxn; i++) {
ans[i][i] = 1;
}
}
int main() {
init();
int n, m, L, u, v;
scanf("%d%d%d", &n, &m, &L);
for(inti = 0; i< m; i++) {
scanf("%d%d", &u, &v);
G[u][v] = 1;
}
MatrixPow(n, L);
int k;
scanf("%d", &k);
for(inti = 0; i< k; i++) {
scanf("%d%d", &u, &v);
printf("%lld\n", (ans[u][v] % MOD + MOD) % MOD);
}
return 0;
}
D: 还原二叉树
不同在于后面的步骤。
但是层序不行,层序的左右子树结点在层序序列中可能是分散的。因此必须想办法把左子树所有结点跟右子树所有结点都找出来。
于是可以开两个vector,一个存左子树所有结点的层序,一个存右子树所有结点的层序。然后遍历当前层序序列的所有结点,根据中序序列判断其属于左子树还是右子树,如果是左子树就push_back到左子树的vector,否则就push_back到右子树的vector。
这样就可以继续递归了,递归参数中用vector表示层序,而中序可以仍然用数组下标。 代码:http://wendang.chazidian.com/10616131/
#include <cstdio>
#include <cstring>
#include <vector>
using namespace std;
constintmaxn = 50;
struct node {
int data;
node* lchild;
node* rchild;
};
int in[maxn]; //中序
//当前二叉树的层序序列为layer,中序序列区间为[inL, inR]
//create函数返回构建出的二叉树的根结点地址
node* create(vector<int> layer, intinL, intinR) {
if(layer.size() == 0) {
return NULL;
}
node* root = new node; //新建一个新的结点,用来存放当前二叉树的根结点
root->data = layer[0]; //新结点的数据域为根结点的值
int k;
for(k = inL; k <= inR; k++) {
if(in[k] == layer[0]) {
break;
}
}
vector<int>layerLeft;
vector<int>layerRight;
for(inti = 1; i<layer.size(); i++) {
boolisLeft = false;
for(int j = inL; j < k; j++) {
if(layer[i] == in[j]) {
isLeft = true;
break;
}
}
if(isLeft) {
layerLeft.push_back(layer[i]);
} else {
layerRight.push_back(layer[i]);
}
}
root->lchild = create(layerLeft, inL, k - 1); root->rchild = create(layerRight, k + 1, inR); return root; //返回根结点地址 }
intnum;
voidpreOrder(node* root,int n) { if(root == NULL) {
return;
}
printf("%d", root->data);
num++;
if(num< n) printf(" ");
elseprintf("\n");
preOrder(root->lchild, n);
preOrder(root->rchild, n);
}
voidpostOrder(node* root,int n) { if(root == NULL) {
return;
}
postOrder(root->lchild, n);
postOrder(root->rchild, n);
printf("%d", root->data);
num++;
if(num< n) printf(" ");
elseprintf("\n");
}
int main() {
vector<int> layer;
int n, temp;
scanf("%d", &n);
for(inti = 0; i< n; i++) {
scanf("%d", &temp);
layer.push_back(temp);
下载文档
热门试卷
- 2016年四川省内江市中考化学试卷
- 广西钦州市高新区2017届高三11月月考政治试卷
- 浙江省湖州市2016-2017学年高一上学期期中考试政治试卷
- 浙江省湖州市2016-2017学年高二上学期期中考试政治试卷
- 辽宁省铁岭市协作体2017届高三上学期第三次联考政治试卷
- 广西钦州市钦州港区2016-2017学年高二11月月考政治试卷
- 广西钦州市钦州港区2017届高三11月月考政治试卷
- 广西钦州市钦州港区2016-2017学年高一11月月考政治试卷
- 广西钦州市高新区2016-2017学年高二11月月考政治试卷
- 广西钦州市高新区2016-2017学年高一11月月考政治试卷
- 山东省滨州市三校2017届第一学期阶段测试初三英语试题
- 四川省成都七中2017届高三一诊模拟考试文科综合试卷
- 2017届普通高等学校招生全国统一考试模拟试题(附答案)
- 重庆市永川中学高2017级上期12月月考语文试题
- 江西宜春三中2017届高三第一学期第二次月考文科综合试题
- 内蒙古赤峰二中2017届高三上学期第三次月考英语试题
- 2017年六年级(上)数学期末考试卷
- 2017人教版小学英语三年级上期末笔试题
- 江苏省常州西藏民族中学2016-2017学年九年级思想品德第一学期第二次阶段测试试卷
- 重庆市九龙坡区七校2016-2017学年上期八年级素质测查(二)语文学科试题卷
- 江苏省无锡市钱桥中学2016年12月八年级语文阶段性测试卷
- 江苏省无锡市钱桥中学2016-2017学年七年级英语12月阶段检测试卷
- 山东省邹城市第八中学2016-2017学年八年级12月物理第4章试题(无答案)
- 【人教版】河北省2015-2016学年度九年级上期末语文试题卷(附答案)
- 四川省简阳市阳安中学2016年12月高二月考英语试卷
- 四川省成都龙泉中学高三上学期2016年12月月考试题文科综合能力测试
- 安徽省滁州中学2016—2017学年度第一学期12月月考高三英语试卷
- 山东省武城县第二中学2016.12高一年级上学期第二次月考历史试题(必修一第四、五单元)
- 福建省四地六校联考2016-2017学年上学期第三次月考高三化学试卷
- 甘肃省武威第二十三中学2016—2017学年度八年级第一学期12月月考生物试卷
网友关注
- 屌丝也能愉快玩耍的七个欧洲滑雪场
- 煤矿防治水
- 山西XX煤业有限公司煤矿安全生产规章制度和操作规程汇编(全套)
- 煤矿安全生产责任制汇编
- 国有煤矿平安质量标准化标准及考察评分办法
- 四川省公路工程招标文件范本
- 你可能还没去过的14家怪咖餐厅
- 煤炭集团工程管理通用表单
- 资深吃货在巴黎不能错过的五家顶级餐馆
- 煤矿职工安全手册
- 在伦敦不能错过的5家咖啡馆
- 煤矿生产安全管理制度
- 电影中的十大浪漫野餐地
- 露天煤业2013年报管理制度排名_薪酬报告(采矿业总资产周转率)内蒙古霍林河露天煤业股份有限公司_@九舍会智库
- 在柏林不能错过的五家餐馆
- 资深吃货在纽约不能错过的五家餐馆
- 必须“到此一游”的十大天然浴场
- 第六章 特殊钻井工艺技术
- 露天矿安全标准化管理手册
- 防灭火措施
- 旅游行业关键字词库
- I DO!全球十大户外婚礼举办地
- 旅行打包必备21个小贴士
- 到世界尽头寻找床:十大偏远酒店
- 井下安全系统“六大系统”建设实施方案
- 对美国旅游业现状的调研报告
- [doc] 发展乡村旅游为贵州喀斯特山区的农村经济输血
- 矿压监测系统--冲击地压监测C
- 走出汽车机油使用的误区
- 全球最奇特的十大婚礼举办地
网友关注视频
- 苏教版二年级下册数学《认识东、南、西、北》
- 北师大版数学四年级下册3.4包装
- 苏科版数学 八年级下册 第八章第二节 可能性的大小
- 北师大版小学数学四年级下册第15课小数乘小数一
- 六年级英语下册上海牛津版教材讲解 U1单词
- 沪教版牛津小学英语(深圳用)五年级下册 Unit 1
- 第五单元 民族艺术的瑰宝_16. 形形色色的民族乐器_第一课时(岭南版六年级上册)_T3751175
- 【部编】人教版语文七年级下册《逢入京使》优质课教学视频+PPT课件+教案,安徽省
- 【部编】人教版语文七年级下册《泊秦淮》优质课教学视频+PPT课件+教案,广东省
- 青岛版教材五年级下册第四单元(走进军营——方向与位置)用数对确定位置(一等奖)
- 沪教版牛津小学英语(深圳用) 四年级下册 Unit 3
- 外研版英语三起5年级下册(14版)Module3 Unit1
- 3月2日小学二年级数学下册(数一数)
- 第4章 幂函数、指数函数和对数函数(下)_六 指数方程和对数方程_4.7 简单的指数方程_第一课时(沪教版高一下册)_T1566237
- 冀教版小学数学二年级下册第二单元《有余数除法的整理与复习》
- 外研版英语七年级下册module1unit3名词性物主代词讲解
- 第8课 对称剪纸_第一课时(二等奖)(沪书画版二年级上册)_T3784187
- 沪教版八年级下册数学练习册21.4(1)无理方程P18
- 冀教版英语三年级下册第二课
- 二次函数求实际问题中的最值_第一课时(特等奖)(冀教版九年级下册)_T144339
- 《小学数学二年级下册》第二单元测试题讲解
- 【部编】人教版语文七年级下册《老山界》优质课教学视频+PPT课件+教案,安徽省
- 七年级英语下册 上海牛津版 Unit9
- 外研版英语三起6年级下册(14版)Module3 Unit1
- 沪教版牛津小学英语(深圳用) 五年级下册 Unit 7
- 北师大版八年级物理下册 第六章 常见的光学仪器(二)探究凸透镜成像的规律
- 第五单元 民族艺术的瑰宝_16. 形形色色的民族乐器_第一课时(岭南版六年级上册)_T1406126
- 化学九年级下册全册同步 人教版 第22集 酸和碱的中和反应(一)
- 沪教版牛津小学英语(深圳用) 五年级下册 Unit 10
- 【部编】人教版语文七年级下册《过松源晨炊漆公店(其五)》优质课教学视频+PPT课件+教案,江苏省
精品推荐
- 2016-2017学年高一语文人教版必修一+模块学业水平检测试题(含答案)
- 广西钦州市高新区2017届高三11月月考政治试卷
- 浙江省湖州市2016-2017学年高一上学期期中考试政治试卷
- 浙江省湖州市2016-2017学年高二上学期期中考试政治试卷
- 辽宁省铁岭市协作体2017届高三上学期第三次联考政治试卷
- 广西钦州市钦州港区2016-2017学年高二11月月考政治试卷
- 广西钦州市钦州港区2017届高三11月月考政治试卷
- 广西钦州市钦州港区2016-2017学年高一11月月考政治试卷
- 广西钦州市高新区2016-2017学年高二11月月考政治试卷
- 广西钦州市高新区2016-2017学年高一11月月考政治试卷
分类导航
- 互联网
- 电脑基础知识
- 计算机软件及应用
- 计算机硬件及网络
- 计算机应用/办公自动化
- .NET
- 数据结构与算法
- Java
- SEO
- C/C++资料
- linux/Unix相关
- 手机开发
- UML理论/建模
- 并行计算/云计算
- 嵌入式开发
- windows相关
- 软件工程
- 管理信息系统
- 开发文档
- 图形图像
- 网络与通信
- 网络信息安全
- 电子支付
- Labview
- matlab
- 网络资源
- Python
- Delphi/Perl
- 评测
- Flash/Flex
- CSS/Script
- 计算机原理
- PHP资料
- 数据挖掘与模式识别
- Web服务
- 数据库
- Visual Basic
- 电子商务
- 服务器
- 搜索引擎优化
- 存储
- 架构
- 行业软件
- 人工智能
- 计算机辅助设计
- 多媒体
- 软件测试
- 计算机硬件与维护
- 网站策划/UE
- 网页设计/UI
- 网吧管理