华为C++笔试题及答案 下载本文

1.static有什么用途?(请至少说明两种)

1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。 2) 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。

3) 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范围内使用

2.引用与指针有什么区别?

1) 引用必须被初始化,指针不必。

2) 引用初始化以后不能被改变,指针可以改变所指的对象。 3) 不存在指向空值的引用,但是存在指向空值的指针。 3.描述实时系统的基本特性

在特定时间内完成特定的任务,实时性与可靠性。

4.全局变量和局部变量在内存中是否有区别?如果有,是什么区别? 全局变量储存在静态数据库,局部变量在堆栈。 5.什么是平衡二叉树?

左右子树都是平衡二叉树 且左右子树的深度差值的绝对值不大于1。 6.堆栈溢出一般是由什么原因导致的? 没有回收垃圾资源。 7.什么函数不能声明为虚函数?

constructor函数不能声明为虚函数。 8.冒泡排序算法的时间复杂度是什么? 时间复杂度是O(n^2)。

9.写出float x 与“零值”比较的if语句。 if(x>0.000001&&x<-0.000001)

10.Internet采用哪种网络协议?该协议的主要层次结构? Tcp/Ip协议

主要层次结构为: 应用层/传输层/网络层/数据链路层/物理层。 11.Internet物理地址和IP地址转换采用什么协议?

ARP (Address Resolution Protocol)(地址解析協議) 12.IP地址的编码分为哪俩部分?

IP地址由两部分组成,网络号和主机号。不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。

13.用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。写出C程序。

循环链表,用取余操作做 14.不能做switch()的参数类型是: switch的参数不能为实型。

1. 以下三条输出语句分别输出什么?[C易] char str1[] = \char str2[] = \const char str3[] = \

const char str4[] = \ const char* str5 = \const char* str6 = \

cout << boolalpha << ( str1==str2 ) << endl; // 输出什么?0 cout << boolalpha << ( str3==str4 ) << endl; // 输出什么?0 cout << boolalpha << ( str5==str6 ) << endl; // 输出什么?1

2. 非C++内建型别 A 和 B,在哪几种情况下B能隐式转化为A?[C++中等] 答:

a. class B : public A { ……} // B公有继承自A,可以是间接继承的 b. class B { operator A( ); } // B实现了隐式转化为A的转化 c. class A { A( const B& ); } // A实现了non-explicit的参数为B(可以有其他带默认值的参数)构造函数

d. A& operator= ( const A& ); // 赋值操作,虽不是正宗的隐式类型转换,但也可以勉强算一个

3. 以下代码中的两个sizeof用法有问题吗?[C易]

void UpperCase( char str[] ) // 将 str 中的小写字母转换成大写字母 {

for( size_t i=0; i

char str[] = \

cout << \字符长度为: \UpperCase( str ); cout << str << endl;

答:str作为参数传递后,在UpperCase中sizeof(str) =1;

4. 以下代码有什么问题?[C难]

void char2Hex( char c ) // 将字符以16进制表示 {

char ch = c/0x10 + '0'; if( ch > '9' ) ch += ('A'-'9'-1); char cl = c%0x10 + '0'; if( cl > '9' ) cl += ('A'-'9'-1); cout << ch << cl << ' '; }

char str[] = \中国\

for( size_t i=0; i

5. 以下代码有什么问题?[C++易] struct Test {

Test( int ) {} Test() {} void fun() {} };

void main( void ) {

Test a(1); a.fun();

Test b(); 答:Test b; b.fun(); }

6. 以下代码有什么问题?[C++易]

cout << (true?1:\应该是同种类型,‘1’是隐式的将字符类型转换成int型,“1”是字符串不能自动转换)

7. 以下代码能够编译通过吗,为什么?[C++易] unsigned int const size1 = 2; char str1[ size1 ];

unsigned int temp = 0; cin >> temp;

unsigned int const size2 = temp; char str2[ size2 ];

答:不能用变量 给const常量赋值

8. 以下代码中的输出语句输出0吗,为什么?[C++易] struct CLS {

int m_i;

CLS( int I ) : m_i(i) {} CLS() {

CLS(0); 答:在CLS()中CLS(0)创建了另一个对象,所以并

没有对obj对象进行赋值,而是其他对象赋值。

} };

CLS obj;

cout << obj.m_i << endl;

不能,因为m_i没有初始化,会付一个很大的数,

9. C++中的空类,默认产生哪些类成员函数?[C++易] 答:

class Empty {

public:

Empty(); // 缺省构造函数 Empty( const Empty& ); // 拷贝构造函数 ~Empty(); // 析构函数 Empty& operator=( const Empty& ); // 赋值运算符 Empty* operator&(); // 取址运算符 const Empty* operator&() const; // 取址运算符 const };

10. 以下两条输出语句分别输出什么?[C++难]

float a = 1.0f; cout << (int)a << endl; cout << (int&)a << endl;

cout << boolalpha << ( (int)a == (int&)a ) << endl; // 输出什么? Float b = 0.0f; cout << (int)b << endl; cout << (int&)b << endl;

cout << boolalpha << ( (int)b == (int&)b ) << endl; // 输出什么?

11. 以下反向遍历array数组的方法有什么错误?[STL易]

vector array;(vector没有给定具体类型也没有说明是模板类型) size_type 是无符号整数,当j=0

时,做减1操作不会得到-1,而是得到最大的无符号整数,因此永远不会退出循环

答:vector array(100); array.push_back( 1 ); array.push_back( 2 ); array.push_back( 3 );

for( vector::size_type i=array.size()-1; i>=0; --i) // 反向遍历array数组 {

cout << array[i] << endl; }

12. 以下代码有什么问题?[STL易] typedef vector IntArray; IntArray array; array.push_back( 1 ); array.push_back( 2 );