NEC面试攻略:二叉树遍历与编译过程详解

4星 · 超过85%的资源 需积分: 9 10 下载量 83 浏览量 更新于2024-09-14 收藏 56KB DOC 举报
在NEC的面试和笔试中,特别是第二部分,考察了一些基础的计算机科学概念和技术理解。以下是一些关键知识点的详细解析: 1. **二叉树的中序遍历**: - 题目要求根据前序和后序遍历来推断中序遍历,这是一个典型的二叉树重构问题。虽然前序和后序可以确定部分结构,但仅凭这两者无法唯一确定中序,因为不同的前序和后序序列可能导致不同的中序。要确定中序,中序遍历必须已知,或者至少有一个额外的遍历(如层次遍历)。如果中序遍历未知,可能需要递归方法来重建二叉树。 2. **编译过程**: - 编译过程包括预处理、编译和链接三个主要阶段,其中预处理和编译是必不可少的,而汇编是将高级语言代码转换为机器语言的过程,可有可无。汇编阶段通常在编译器内部进行,链接则是将编译后的各个模块合并成可执行文件。 3. **操作系统死锁**: - 死锁发生在并发进程中因资源竞争导致的一种状态,其四个必要条件是:互斥(一次只有一个进程访问资源)、占有并等待(进程已经占用了某些资源且等待其他资源)、不可抢占(一旦占有资源,除非释放,否则不能被其他进程抢占)、循环等待(进程形成环路,每个进程都在等待另一个进程释放资源)。 4. **数据库基础知识**: - 数据库语言通常指的是SQL(Structured Query Language),它用于管理和操作数据库。数据库中的两个基本操作是查询(检索数据)和更新(修改数据)。 5. **排序算法与查找**: - 常见的排序算法有冒泡排序、选择排序、插入排序、快速排序、归并排序等,其中插入排序是稳定的,意味着相等元素的相对顺序不会改变。在100个节点中,二分查找法理论上最多需要7次比较(对数查找复杂度),但实际上具体次数取决于目标值在列表中的位置。 6. **计算机网络和操作系统概念**: - OSI模型有七层,中继器在物理层,网桥在数据链路层,路由器在网络层。操作系统是系统软件,进程调度通常通过操作系统提供的API(如Windows的CreateThread或Linux的fork)实现,主要包括进程创建、进程调度和进程结束这三个基本过程。 NEC的面试和笔试题目的重点在于检验候选人的基础理论知识、逻辑思维能力以及对常见数据结构和算法的理解,同时也涉及了操作系统和网络的基础概念。掌握这些知识点对于应聘NEC的职位至关重要。

优化这段代码#include <REGX52.H> #include "lcd1602.h" #include "send_IR.h" #include "notsend_IR.h" #include "keybored.h" #include "Delay.h" sbit IR_EN = P2^0; void Send_NEC_0() { NotSend_IR(19); Send_IR(19); } void Send_NEC_1() { NotSend_IR(60); Send_IR(19); } void send(unsigned char s1,unsigned char s2) { unsigned char temp,i; Send_NEC_1(); Send_NEC_0(); Send_NEC_1(); Send_NEC_1(); Send_NEC_0(); Send_NEC_0(); Send_NEC_1(); Send_NEC_0(); Send_NEC_0(); Send_NEC_1(); Send_NEC_0(); Send_NEC_0(); Send_NEC_1(); Send_NEC_1(); Send_NEC_0(); Send_NEC_1(); temp = s1 & 0x001; for(i = 0;i<12;i++) { if(temp) { Send_NEC_1(); } else { Send_NEC_0(); } temp = temp>>1; } Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); temp = s2 & 0x001; for(i = 0;i<12;i++) { if(temp) { Send_NEC_1(); } else { Send_NEC_0(); } temp = temp>>1; } //????? Send_NEC_1(); Send_NEC_1(); Send_NEC_1(); Send_NEC_1(); } void Send1(unsigned char s1,unsigned char s2) { Send_IR(167); NotSend_IR(167); Send_IR(167); send(s1,s2); Send_IR(167); NotSend_IR(167); Send_IR(167); send(s1,s2); Send_IR(167); NotSend_IR(167); Send_IR(167); Send_NEC_1(); Send_NEC_1(); Send_NEC_0(); Send_NEC_1(); Send_NEC_0(); Send_NEC_1(); Send_NEC_0(); Send_NEC_1(); Send_NEC_0(); Send_NEC_1(); Send_NEC_1(); Send_NEC_0(); Send_NEC_0(); Send_NEC_1(); Send_NEC_1(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_0(); Send_NEC_1(); Send_NEC_0(); Send_NEC_0(); Send_NEC_1(); Send_NEC_0(); Send_NEC_1(); Send_NEC_0(); }

2023-05-30 上传