2016嵌入式软件工程师笔试题及答案

发布时间:2016-10-22 00:00:00 编辑:嘉辉 手机版

  15:算术运算符,赋值运算符和关系运算符的运算优先级按从高到低依次为

  A.算术运算、赋值运算、关系运算

  B.算术运算、关系运算、赋值运算

  C.关系运算、赋值运算、算术运算

  D.关系运算、算术运算、赋值运算

  参考答案:B

  16:设#define N 3

  #define Y(n) ((N+1)*n)

  则表达式2*(N+Y(5+1))的值是

  A.42

  B.48

  C.54

  D.出错

  参考答案:B

  17:表达式 strcmp( “ 3.14 ”,“ 3.278 ” ) 的值是一个

  A.非零整数

  B.浮点数

  C.0

  D.字符

  参考答案: A

  18:设struct

  { short a;

  char b;

  float c;

  }cs;

  则sizeof(cs)的值是

  A.4

  B.5

  C.6

  D.7

  参考答案: D 字节对齐的话应该是8

  19:若变量已正确定义,表达式( j=3 , j++ )的值是

  A.3

  B.4

  C.5

  D.0

  参考答案:A

  20:C 语言中运算对象必须是整型的运算符是

  A.%

  B./

  C.!

  D.**

  参考答案:A

  二、简答题

  21:打印一个N*N的方阵,N为每边字符的个数( 3〈N〈20 ),要求最外层为“X”,第二层为“Y”,从第三层起每层依次打印数字0,1,2,3,...

  例子:当N =5,打印出下面的图形:

  X X X X X

  X Y Y Y X

  X Y 0 Y X

  X Y Y Y X

  X X X X X

  22:谈谈COM的线程模型。然后讨论进程内/外组件的差别。

  23:多态类中的虚函数表是Compile-Time,还是Run-Time时建立的?

  参考答案:

虚拟函数表是在编译期就建立了,各个虚拟函数这时被组织成了一个虚拟函数的入口地址的数组.
而对象的隐藏成员--虚拟函数表指针是在运行期--也就是构造函数被调用时进行初始化的,这是实现多态的关键.

  24:#include

  void main()

  { int c;

  while ((c=getchar())!= ′\ n ′ )

  switch(c - ′ 2 ′ )

  { case 0:

  case 1:putchar(c+4);break;

  case 2:putchar(c+4);break;

  case 3:putchar(c+3);break;

  default:putchar(c+2);break;

  }

  printf( ″\ n ″ );

  }

  运行时输入: 2473 ,输出结果:

  参考答案:6897 VC++6.0测试过

  25:用两个栈实现一个队列的功能?

  参考答案:

  设2个栈为A,B, 一开始均为空.入队:

  将新元素push入栈A;出队:

  (1)判断栈B是否为空;

  (2)如果不为空,则将栈A中所有元素依次pop出并push到栈B;

  (3)将栈B的栈顶元素pop出;这样实现的队列入队和出队的平摊复杂度都还是O(1),

  26:写一语句实现x是否为2的若干次幂的判断。

  参考答案:!(X)&(X-1)

  27:解二次方程:a*x*x+b*x+c

  int Quadratic( double a,double b,double c,double& x1,double& x2);

  返回值:解的个数

  28:如何判别一个数是unsigned。

  参考答案;

  #define issignal(x) ((x>=0 && ~x>=0) ? 1:0) //为1是无符号 为0有符号

  29:执行下述程序的输出结果是 ABCDEFCDEFEF 。

  #include

  char b[]="ABCDEF";

  main()

  {

  char *bp;

  for (bp=b;*bp;bp+=2)

  printf("%s",bp);

  printf("\n");

  }

  30:已知一个数组table,用一个宏定义,求出数据的元素个数。

  参考答案:#define NTBL

  #define NTBL (sizeof(table)/sizeof(table[0]))

下页更精彩:首页 上一页 1 2
本文已影响884
+1
0