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月月考生物试卷
网友关注
- 正弦交流电路的稳态分析
- 大学课件:空气呼吸器检验台
- P2P技术相关的信息安全问题研究
- 细胞生物学进展思考题
- 【精品】函数逼近与曲线拟合
- chemical industry pallets
- 环球托业介绍托福阅读如何扩充题库
- 统计过程控制SPC讲座全文
- 第七章 国际货物运输保险.ppt
- 第一章商品和货币
- 托福写作思路浅谈
- 微生物发酵产酶.ppt
- 托福阅读辅导:怎样节省托福阅读时间?
- 托福考试经验分享
- 各类公共场所消防设计施工与验收:汽车库消防安全技术
- 管理学原理题库(闭卷)
- 英汉语篇衔接对比与翻译2
- 医学伦理学试题
- 2000-2005 PBT老托福历年真题
- 机械制图习题集答案67073
- 《精心整理》Mdmera托福口语考试中四种欠佳的表现
- 电大工商管理本科小企业管理的历年试题及答案
- 11,12导数的运算法则
- 怎么才能写出一篇优秀的托福作文?
- 闽南理工学院《中国对外贸易概论》B卷答案
- 大学课件:特征值和特征向量及相似
- Download this article. - IBIS - Effective business planning and
- 闽南理工学院《中国对外贸易概论》考试试卷C出卷
- 酶固定化
- 2015年5月16日托福大范围机经
网友关注视频
- 北师大版数学 四年级下册 第三单元 第二节 小数点搬家
- 8 随形想象_第一课时(二等奖)(沪教版二年级上册)_T3786594
- 沪教版八年级下册数学练习册一次函数复习题B组(P11)
- 19 爱护鸟类_第一课时(二等奖)(桂美版二年级下册)_T502436
- 【部编】人教版语文七年级下册《过松源晨炊漆公店(其五)》优质课教学视频+PPT课件+教案,江苏省
- 【部编】人教版语文七年级下册《逢入京使》优质课教学视频+PPT课件+教案,安徽省
- 冀教版小学数学二年级下册1
- 《小学数学二年级下册》第二单元测试题讲解
- 8.对剪花样_第一课时(二等奖)(冀美版二年级上册)_T515402
- 【获奖】科粤版初三九年级化学下册第七章7.3浓稀的表示
- 河南省名校课堂七年级下册英语第一课(2020年2月10日)
- 冀教版小学数学二年级下册第二单元《有余数除法的整理与复习》
- 七年级英语下册 上海牛津版 Unit5
- 三年级英语单词记忆下册(沪教版)第一二单元复习
- 外研版英语三起6年级下册(14版)Module3 Unit2
- 化学九年级下册全册同步 人教版 第18集 常见的酸和碱(二)
- 冀教版小学数学二年级下册第二单元《租船问题》
- 七年级英语下册 上海牛津版 Unit9
- 北师大版八年级物理下册 第六章 常见的光学仪器(二)探究凸透镜成像的规律
- 第12章 圆锥曲线_12.7 抛物线的标准方程_第一课时(特等奖)(沪教版高二下册)_T274713
- 外研版英语三起6年级下册(14版)Module3 Unit1
- 8.练习八_第一课时(特等奖)(苏教版三年级上册)_T142692
- 【部编】人教版语文七年级下册《逢入京使》优质课教学视频+PPT课件+教案,辽宁省
- 【部编】人教版语文七年级下册《老山界》优质课教学视频+PPT课件+教案,安徽省
- 冀教版英语三年级下册第二课
- 【部编】人教版语文七年级下册《泊秦淮》优质课教学视频+PPT课件+教案,天津市
- 二年级下册数学第三课 搭一搭⚖⚖
- 【部编】人教版语文七年级下册《泊秦淮》优质课教学视频+PPT课件+教案,广东省
- 人教版历史八年级下册第一课《中华人民共和国成立》
- 【部编】人教版语文七年级下册《逢入京使》优质课教学视频+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
- 网吧管理