华为笔试题Word下载.docx
《华为笔试题Word下载.docx》由会员分享,可在线阅读,更多相关《华为笔试题Word下载.docx(10页珍藏版)》请在冰豆网上搜索。
3、
enum
ENUM_A
x1,
y1,
z1
5,
a1,
b1
};
ENUM_A
enumA
y1;
enumB
b1;
请问enumA和enumB的值是多少
1,7
4、若有函数max(a,b),并且函数指针变量p已经指向函数,当调用该函数时正确的调用方法是:
(*p)(a,b)或者p(a,b)
5、对栈S进行下列操作:
push
(1),push(5),pop(),push
(2),pop(),pop(),则此时栈顶元素是:
没有元素,栈空。
6、在一个32位的操作系统中,设void*p=malloc(100),请问sizeof(p)的结果是:
32位操作系统的寻址大小是32位,即4字节。
7、若已定义:
inta[9],*p=a;
并在以后的语句中未改变p的值,不能表示a[1]地址的表达式是:
A)p+1B)a+1C)a++D)++p
C
8、设有如下定义:
unsigned
long
pulArray[]
{6,7,8,9,10};
*pulPtr;
则下列程序段的输出结果是什么
pulPtr
pulArray;
*(pulPtr
+
2)
+=
2;
%d,%d\r\n"
*pulPtr,
2));
A)8,10B)6,8C)7,9D)6,10
D
9、以下程序运行后,输出结果是什么
void
char
*szStr
"
abcde"
;
szStr
%1u\r\n"
szStr);
return;
A)cdeB)字符c的ASCII码值C)字符c的地址D)出错
10、给出以下定义:
X[]
hello"
Y[]
{'
h'
'
e'
l'
o'
则正确的叙述为:
A)数组X和数组Y等价B)数组X和数组Y的长度相同
C)数组X的长度大于数组Y的长度D)数组X的长度小于数组Y的长度
11、在32位X86下,有下列程序
union
k;
i[2];
}
*s,
a;
s
&
s->
i[0]
0x39;
i[1]
0x38;
%x\r\n"
输出结果是:
A)3839B)3938C)380039D)不可预知
A
12、有如下函数定义:
MyFunc(unsigned
ulKey)
(((ulKey
0x000000ffUL)
<
24)|
((ulKey
0x0000ff00UL)
8)
|
0x00ff0000UL)
0xff000000UL)
24));
则MyFunc(0x)的返回值是:
A)0xB)0xC)0xD)0x
13、((a>
b)a:
b)代表什么含义:
A)代表a,b之中较小的那个值
B)代表a,b之中较大的那个值
C)代表a是否比b大
D)语法错误
B
14、某系统总线的一个总线周期包含3个时钟周期,每个总线周期可以传送32位数据。
若总线的时钟频率为33MHz,则总线带宽为多少MB/s
33*10(6)*32/8*10(6)*3
A)11B)22C)33D)44
15、如下定义,则s在内存中占多大空间
struct
aa:
ab:
c;
d;
s;
A)1byteB)2byteC)3byteD)4byte
16、如下定义:
union
tagAAAA
struct
ucFirst;
short
usSecond;
ucThird;
}half_a;
lI;
}number;
在按1字节对齐情况下,sizeof(uniontagAAAA)的大小是:
在按4字节对齐情况下,sizeof(uniontagAAAA)的大小是:
A)4byteB)6byteC)8byteD)12byte
A,C
17、0x在采用BigEndian中内存的排列顺序是,在采用LittleEndian内存中的排列顺序是。
(答案从左到右内存地址依次增加)
A)12345678B)34127856C)78563412D)56781234
A,D
18、关于静态变量,下面说法“不正确”的有:
A)静态变量在堆栈中分配
B)静态变量的作用域一定是局部的,例如在一个文件内或一个函数内
C)静态变量可分为静态局变量和静态全局部变量
D)静态变量存在于数据段中
19、下面正确的有
A)在中断中,不能同步获取信号量,但是可以释放信号量
B)在中断中,可以使用系统调用sleep函数来等待一会儿
C)每一个进程有自己的独立地址空间,每一个线程程序也有自己的独立地址空间
D)CPU占用率为60%,意思是CPU有60%的时间在运行指令40%的时间没有运行指令
20、设有如下定义:
int(*ptr)();
则以下叙述中正确的是:
A)ptr是指向一维数组的指针变量
B)ptr是指向int型数据的指针变量
C)ptr是指向函数的指针,该函数返回一个int型数据
D)ptr是一个函数名,该函数的返回值是指向int型数据的指针
21、在Windows95环境下,定义数组:
int**a[2][4];
则数组a所占用的内存单元为:
A)8字节B)32字节C)64字节D)不确定
22、有国际标准化组织(ISO)和国际电信联盟(ITU-T)共同提出的开放系统互联(OSI)参考模型中共有层,参考模型的最高层则为层。
A)4B)7C)应用D)会话
B,C
23、关于以太网中的ARP协议,描述错误的是:
A)根据IP地址查询其对应的MAC地址
B)根据MAC地址查询其对应的IP地址,便于IP通信
C)通过ARP协议产生的IP和MAC地址的映射,超时会淘汰
D)ARP请求中的MAC地址为广播地址
24、关于TCP、UDP及其上层的应用,描述错误的是:
A)TCP协议面向连接的,UDP协议是面向无连接的
B)UDP不保证数据的可靠传送,而文件的传递时要求必须无错传送的,因而所有基于文件传递的应用都不能基于UDP,如:
TFTP
C)telnet是基于TCP的终端应用,连续输入的多个字符可能会被封装到一个TCP包中
D)在同一个节点上,基于TCP和UDP的应用端口号可以重叠
改错题
1、请指出下面程序的错误
i
10;
b
100;
*p
f(void)
while(--i
0)
*(p++)
b;
参考答案:
(1)p没有分配空间
(2)i是无符号型,自减操作会引发死循环
2、下面函数要实现打印helloworld的功能,请问程序中有何错误
void*
GetMemory()
str[]
helloworld"
str;
Test()
*str
NULL;
str
(char*)
GetMemory();
printf(str);
(1)GetMemory函数返回的地址内容已经被释放。
(2)str是指针,printf(str)打印的是地址,正确的是printf(*str)
3、请问如下代码有什么错误
#defineMAX_SIZE1000
#defineNULL0
#defineTRUE1
#defineFALSE0
XXX
demo(struct
XXX
*p,
size)
*temp;
temp=(struct
XXX*)malloc(sizeof(struct
XXX)*MAX_SIZE);
if
(NULL
==
temp)
FALSE;
memcpy(temp,
p,
sizeof(struct
XXX)*size);
/*其他操作*/
free
(temp);
TRUE;
(1)size可能大于MAX_SIZE,缺少安全检查
(2)p指针未作安全检查
4、如下程序用于把“blue”字符串返回,请指出其中的错误。
*GetBlue()
char*
pcColor;
pcNewColor;
pcColor
blue"
pcNewColor
(char*)malloc(strlen(pColor));
strcpy(pcNewColor,
pcColor);
(1)pcColor没有结束符,导致strcpy错误
(2)pcNewColor分配的长度应该再加1,用来放结束符’\0’
5、请问如下程序段有什么错误
0,
*p1;
p
(unsigned
*)malloc(10000);
p1
p;
for(i
9999;
i++)
*p1
0x100;
p1++;
free(p);
(我找不到明显错误,要么是main函数没有指定返回值类型)
编程题
1、对称数判断问题
请编写一段程序,判断一个正整数是否为对称数(对称数即左右对称的数字,如3、22、121、1331、34543等),不允许利用C语言将数字转换为字符转的库函数。
bool
judgeNumberSymmetry(unsigned
ulNumber)
ulTemp
ulNumber;
/*srccopy*/
ulResult
iMod
(ulTemp)
%
*
10
iMod;
/=
(ulNumber
ulResult)
true;
else
false;
2、排队队列问题
n个人,排成1队,(p1,p2,p3...pn)从第一个人开始从1报数,报数到3的人离开队列,队列里的下一个人继续从1开始报数,以此反复,当数到队列尾时,从队列头部继续报数,这样周而复始,知道队列剩一人。
给一个简单的例:
报数结果如下:
1,2,4,5,7,第一轮,3、6离开队列,7报数1,然后从队列头部继续报数,那么第一个人报数2,如此1,4,5,这样第二轮,位置2和位置7离开队列,并且从队列头部继续报数,第一个人报数1,因为队列尾部的7恰好报数到3.
1,2,这样第三轮,5被淘汰;
然后开始位置1的人报数1,最后位置1正好报数3,于是离开队列,最后剩下的人是2。
这样给定7个人,原始位置2的人是剩下的人。
请事先一个简单程序,实现上述问题,程序输入n,输出那个最后剩下的人的原始位置。
参考答案:
(仅提供算法伪代码)
/*usequeue*/
getLast()
iCur
1;
iPop;
!
iCur++;
iPop
()
(3
iCur)
(iPop);
();