移远通信笔试题

限时60分钟

1.下列关于栈叙述正确的是 A

A) 栈顶元素最先能被删除

B)栈顶元素最后才能被删除

C)栈底元素永远不能被删除

D)以上三种都不对

在栈中,最后被压入的元素总是在栈顶上方,而栈顶元素总是最先被弹出的元素。
因此,在进行删除操作时,栈顶元素会最先被删除。

所以,选项 A 是正确的。

2.下列叙述中正确的是 B

A) 有一个以上根结点的数据结构不一定是非线性结构
B) 只有一个根结点的数据结构不一定是线性结构
C)循环链表是非线性结构
D)双向链表是非线性结构

选项 B 是正确的。只有一个根结点的数据结构不一定是线性结构。
选项 A 是错误的。拥有一个以上根结点的数据结构一定是非线性结构,因为它们无法形成单一的层次结构。
选项 C 和 D 都是错误的。循环链表和双向链表都是线性结构,因为它们沿着一个线性序列连接元素。
循环链表中,最后一个元素链接到了第一个元素,从而形成了一个环。
而双向链表中,每个节点都包含两个指针,分别指向前驱节点和后继节点,这样可以支持双向遍历。

3.某二又树共有7个结点,其中叶子结点只有1个,则该二叉树的深度为(假设根结点在第1层)

A)3 B) 4 C)6 D)7

在这里插入图片描述

4.若有定义语句:int a=3,b=2,c=1;,以下选项中错误的赋值表达式是

A)a=(b=4)=3;
B)a=b=c+1;
C) a=(b=4)+c;
D)a=1+(b=c=4);

选项 A 是错误的,因为 b=4 的结果是 4,所以 a=(b=4)=3 等价于 a=3 和 b=4,但是在 C 语言中,赋值操作返回被赋的值,因此 (b=4) 的结果是 4。然后再将 4 赋值给 b,使得 b 的值变成了 4。这时候再把 b=4 和 a=3 再进行一次赋值运算,就等价于 (4=3),由于左值必须是可修改的,因此会产生一个编译错误。

选项 B、C 和 D 都是正确的,其解释如下:

选项 B:首先计算 c+1 的结果为 2,然后将其赋值给 b,使得 b 的值变成了 2。接着将 b 赋值给 a,使得 a 的值也变成了 2。
选项 C:首先计算 (b=4) 的结果为 4,然后将其加上 c=1 的结果为 5,最后将 5 赋值给 a,使得 a 的值变成了 5。
选项 D:首先执行表达式 b=c=4,将 c 和 b 的值都变成了 4。接着计算 1+(b=c=4) 的结果为 5,最后将 5 赋值给 a,使得 a 的值变成了 5。
因此,选项 A 是错误的。

5.若有定义语句:char s[3][10],(*k)[3], *p;,则以下赋值语句正确的是

A)p=s;
B) p=k;
C)p=s[0];
D)k=s;

6.一棵二叉树的中序遍历结果为DBEAFC,前序遍历结果为ABDECF,则后序遍历结果为 D

A)DBEFCA
B) DEBCAF
C) DEBFAC
D) DEBFCA
在这里插入图片描述

7.下列三条指针定义语句哪些表示含义相同的 B

(1)const char p; (2)char * const p; (3)char constp;
A)1,2
B) 1,3
C) 2,3
D) 1,2,3都相同
在这里插入图片描述

8.有以下程序void Func(char str[100]){print("%d”,sizeof(str));}运行结果是 C

A)1
B)2
C)4
D)8
E)100
F)根据传入字符串size大小

9.有以下程序printf(“%d”,sizeof(struct data)+sizeof(max));运行结果是 D

typedef union {
	long i; int k[5];char c: 
}DATA; 
typedef struct data 
{
	int cat;
	DATA cow;
	doubie dog; 
} animal; 
DATA max; 

A)29
B)12
C)16
D) 52
E)58
F)32

10.有以下程序程序运行后的输出结果是 B

#define S(x) 4*(x)*x+1
main 
{ 
	int k = 5, j = 2;
	printf("%d\r", S(k+j));
}

A)197 B)143 C)33 D)28 E)66 F)208

11.传入参数0x23调用下面的函数fn()会得到返回值是 E

#define x(y)((y<<2) | y)
unsigned int fn(unsigned int u) 
{
  	return x(u);
}

A) will not compile
B)0xdc
C)0xcd
D)0xbe
E) 0xaf
F) 0xg0

12. <多选>在多线(进)程编程中,线(进)程间通信方式有 ABCDEF

A)信号
B)信号量
C)消息队列
D)共享内存
E) 管道
F)套接字

13.<多选> 通信双方为了建立串行UART)通信,须要解决哪些问题 ABCDEF

A)波特率
B)数据位数
C)奇偶校验
D)数据流控制
E)起始位
F)停止位

14.<填空>

程序的局部变量存储于 中,全局变量存储于全局静态区,动态申请数据存储于

15. <填空>

TCP通信中端口的作用是 标识使用TCP协议的应用进程

16.<填空>

请定义该函数指针类型,带一个整型参数和void* 的返回类型

void * (*pfun) (int arg);

17. <填空>

整型变量a,设置a的bit 3;清除a的bit 3:(保持其它位不变)。
设置a bit 3:

a |= (0x01 << 3);

清除a的bit3 保持其他位不变:

a &= ~(0x01 << 3);

18. <填空>

关键字 volatile有什么含意

在计算机编程中,关键字"volatile"通常用于声明一个变量是易变的(即具有不稳定性)。它告诉编译器该变量的值可能会在程序的其他位置改变,因此不应该对该变量进行优化或缓存。这样可以确保访问该变量时始终从内存中读取最新的值,而不是使用已经缓存的旧值。
在多线程编程中,使用"volatile"变量可以确保不同线程之间的数据同步,因为它们都从内存中读取最新的变量值。否则,在没有同步机制的情况下,并发线程可能会读取到过期的变量值,从而导致不可预测的结果。

一个既可以是const还可以是volatile么?为什么?

可以。比如只读的状态寄存器

19. <填空>

ISO的七层模型是什么? tcp/udp 是属于哪一层? tcp/udp 有何优缺点?

从高往上依次是物理层、数据链路层、网络层、传输层、会话层、表示层、应用层
TCP/UDP属于传输层;

20. <填空> 给出下列程序执行结果

(1) chat str[] = “Hello”; char *p = str;

1sizeof(str) =  6
2sizeof(p) = 4

(2)void *p = maloc( 100); int n = 10;

1sizeof(p) = 4
2sizeof(n) = 4

21.请找出下列代码片段中不正确的地方,并提供一种你认为合理的解决方案。

(1)

void test1()
{ 
	char string[10];
	char* str1="0123456789";
	strcpy( string, str1 );
}

(2)

void test3(char* str1)
{
	char string[10];
	if( strlen( str1 ) <= 10 ) 
		strcpy( string, str1);
}

22下面的程序执行后会有什么输出?

(1)

int sum(int a) 
{
	auto int c = 0;
	static int b = 3;
	
	c += 1;
	b += 2;
	return(a+b+c);
}

void main()
{
	int i; int a = 2;
	for(i = 0: i < 5: i++)
	{
		printf("%d," sum(a));
	}
}

这个程序输出是:8,10,12,14,16
(2)

int func(x)
{
	int countx = 0;
	
	while(x)
	{ 
		countx++;
		x =x&(x-1);
	}
	return countx:
}

void main()
{
	int ret = func(263);
}

ret变量为 4

23.<编程>定义一个函数,该函数功能为:设置一绝对地址为0x67a9 的整型变量的值为0xaa66,并将该值显示在屏幕上。(编译器是一个纯粹的ANSI编译器)

void func(void)
{
	int *p = (int *)0x67a9;
	*p = 0xaa66;
	printf("%d", *p);
}

24.中断是嵌入式系统中重要的组成部分,这导致了很多编译开发商提供一种扩展一让标准C支持中断。具代表事实是,产生了一个新的关键字 interrupt。下面的代码就使用了_interrupt 关键字去定义了一个中断服务子程序(ISR),请评论一下这段代码的。

__interrupt double compute area (double radius)
{
	double area = PI* radius * radius;
	sleep(1);
	printf(" Area = %f", area);
	return area;
}

中断不能有返回值和参数
最好不好在中断函数做浮点运算和打印操作,因为耗时长,中断处理追求快进快出
不要再中断函数中调用sleep这种引起系统阻塞函数,因为在中断中系统是不调度,这可能引起系统崩溃

25.<编程>设计一个函数来获知 stack 是向高地址还是低地址方向增长。(使用 C,不建议用伪码)

#include <stdio.h>

void find_stack_direction(int *p)
{
	int val;
	
	printf("%p %p\r\n", p, &val);
	if (p > &val)    /* 栈底变量地址比栈顶变量地址大,说明向下增长 */
	{
		printf("stack diretion: grow down\r\n");
	}
	else
	{
		printf("stack diretion grow high\r\n");
	}
}

26.<编程>有一个单向链表,请编写代码反转该链表。(数据类型可以任意定义,使用 C,不建议用伪码

struct Node {
    void *data;            // 数据指针,数据类型任意
    struct Node *next;     // 指向下一个节点的指针
};

struct Node* reverseList(struct Node* head) {
    struct Node* prev = NULL;
    struct Node* curr = head;
    
    while (curr != NULL) {
        struct Node* next = curr->next;
        curr->next = prev;
        prev = curr;
        curr = next;
    }
    
    return prev;
}

27. Please translate English into Chinese

Tracker 007 is a multi-functional tracker. Combining with GPRS and high performance GPS, the devicecan be used to track and report device’s position and status to mobile phone through SMS or Main DattServer (MDS) through HTTP The operation modes include continuous tracking and position lock (park). So:buttons can be used to send emergency call. All configurations can be set through SMS or USB interface. The wireless communication includes UDP, TCP/IP,HTTP and SMS. With MTK EPO, it can get shorter TTFF atdistressed environment.

跟踪器007是一款多功能跟踪器。该设备结合GPRS和高性能GPS,可通过短信或HTTP向手机报告设备的位置和状态。
操作模式包括连续跟踪和位置锁定(泊车)。
所以:按钮可以用来发送紧急呼叫。所有配置都可以通过短信或USB接口进行设置。
无线通信包括UDP、TCP/IP、HTTP和SMS。使用MTK EPO,可以在恶劣的环境下获得更短的TTFF。

28.请用英文写信(5分)

客户 Peter 很焦急的写来邮件请求您的帮助。可是由于出差,你耽误了两天才看到邮件。并且他提出的关于蜂窝网络方面的问题并不是你非常熟悉的,你得介绍相关的技术人员和他沟通。请你马上回一个由件给Peter,另外邮件内容中蜂窝网问题的答复要包含如下主要信息
当个人和商业用户需要像手机网络一样简单易用的互联网连接时,移动计算提供简易的方案,以便在任何手机能够工作的地方通过蜂窝网络让上网本、膝上电脑或者其他电子设备连接网络。蜂窝网络是提供任何时间和任何地方低价的数据连接的理想选择

专业面试我的技巧和经验: 一、 巧妇难为无米之炊,事前做一些功课是必须的,把自己学习过的和应聘岗位相关的内容复习下,比如性能与算法岗位:本科电子信息工程和通信工程这些课程肯定学过,通信原理,信息论和编码,信号与系统,数字信号处理,复习一下掌握大概的轮廓一个星期应该差不多可以搞定. 二、 善于引导面试官,比如当面试官问到什么问题不懂的时候,避免连问几个都不懂,可以尝试这么说:我***方面的知识比较匮乏,不是很了解,但是我对***的知识还是比较熟习,我觉得***的知识在我们华为性能与算法工程师必须要掌握的吧。以我面试为例,面试问我3G和4G的关键技术,已经这些关键技术的基本原理,我是做雷达信号处理的,确实不懂。我就和面试官说:对不起,因为研究生期间主要做的雷达信号处理的工作,我对移动通信的知识了解甚少,但是我对移动通信的基础只是比如通信原理和调制解调技术还有一定的了解(当然这都是我事先复习好的),我觉得无论什么类型的通信技术都离不开这些基本的理论。接着面试官就让我说信源编码和信道编码的作用已经他们通常采用的方法,当然我也就能对答如流了。所以,引导很重要。 三、 专业面试对自己简历上不要为了蒙骗面试官,写的项目自己捡不熟悉,对简历上的东西一问三不知,语言表达不清楚,说不半天不能告诉面试官你做的工作内容和意义,这个很不好。 群面 一般10-14个人,看当天应聘的人数而定,分2组,一个话题,让排序之类的,或者辩论之类的,不同的组会抽到不同的问题,不同的地方也会有不同的问题,在这里把问题说出来没什么意义,这一轮会有很多意想不到的情况,比如这组我本来不是选为组长,但是在做总结的时候面试官让我做总结,或者突然问你刚才某某同学说的话你同意吗,或者突然说你今天脸色好像不好看之类的,所以灵机应变才是王道。群面一般要自我介绍,自我介绍要简短,不要说太多,我建议按以下几个方面说,自己学校专业、来自哪里、然后说自己学习,主要稍微说下自己的项目,说下名字就OK了,然后说自己做项目获得成果,比如发表文章,专利和之类的。然后说自己优点和缺点,一般情况下优点缺点都要说,而且我觉得最好优点缺点自己多准备几个,免得到时候你要说的前面的人都说了,就像我们这组:我开始说缺点的时候说我性格比较急,做什么事情都想快点做完,午觉也不睡,但是经常适得其反,中午不谁觉,下午就工作效率低。后面好几个同学说的时候都这么说了,惹的面试官说,你们重复一个东西说。说缺点的时候大家要慎重,不要说和自己工作相关的缺点,比如我们那个组一个同学说:我的缺点就是比较随性,重要场合经常穿拖鞋为此挨了不少批评。 面试官:。。。。(前面省略了一些),你这种随行的行为有同学提醒过你吗?
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

欲盖弥彰1314

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值